python中字符串比较是基于字典序的_Python字符串字典集合
字符串
定义:字符串是一个有序的字符的集合,用于存储和表示基本的文本信息,'单引号' 或"双引号" 或 """三引号"""中间包含的内容称之为字符串
创建: s ='Hello,Eva!How are you?'
特性:
1.按照从左到右的顺序定义字符集合,下标从0开始顺序访问,有序
2.可以进行切片操作
3.不可变,字符串是不可变的,不能像列表一样修改其中某个元素,所有对字符串的修改操作其实都是相当于生成了一份新数据。
补充:
1.字符串的单引号和双引号都无法取消特殊字符的含义,如果想让引号内所有字符均取消特殊意义,在引号前面加r,如name=r’l\thf’
字符串的常用操作
字符串操作方法有非常多,但有些不常用 ,我们只讲重要的一些给大家,其它100年都用不上的有兴趣可以自己研究
字符串的构造函数:
str(obj="") 将对象转换为字符串
S.isdigit()判断字符串中的字符是否全为数字
S.isalpha()判断字符串是否全为英文字母
S.islower()判断字符串所有字符是否全为小写英文字母
S.isupper() 判断字符串所有字符是否全为大写英文字母
S.isspace()判断字符串是否全为空白字符
S.center(width,fillchar=' ')将原字符串居中,左右默认填充空格,也可以指定其他字符填充
S.count(sub[, start[, end]]) :取一个字符串中子串的个数 sub:所要获取的字符串 start:起始位置 end:结束位置
S.find(sub[, start[,end]]): 获取字符串中子串sub的索引,失败返回-1 start:起始位置 end:结束位置
S.strip()返回去掉左右空白字符的字符串
S.lstrip() 返回去掉左侧空白字符的字符串
S.rstrip() 返回去掉右侧空白字符的字符串
S.upper()生成将英文转换为大写的字符串
S.lower()生成将英文转换为小写的字符串
S.replace(old, new[, count])将原字符串的old用new代替,生成一个新的字符串 count:更换的次数
S.startswith(prefix[, start[, end]])返回S是否是以prefix开头,如果以prefix开头返回True,否则返回False,
S.endswith(suffix[, start[, end]]) 返回S是否是以suffix结尾,如果以suffix结尾返回True,否则返回False
S.swapcase()大小写翻转
S.capitalize()返回字符串的大写版本,更具体地说,使第一个字符大写,其余字符小写
S.casefold()返回适合无大小写比较的字符串版本。
S.index(sub[, start[, end]])返回S中找到子字符串子的最低索引,使sub包含在S[start:end]中。可选
S. ljust(width, fillchar=' ')返回长度和宽度为左对齐的字符串,填充使用指定的填充字符(默认为空格)完成。
S. rjust( width, fillchar=' ')返回长度和宽度为右对齐的字符串,填充使用指定的填充字符(默认为空格)完成。
S.split(self, /, sep=None, maxsplit=-1) 返回字符串中的单词列表,使用sep作为分隔符字符串。
S.join(self, iterable,) 连接任意数量的字符串,方法被调用的字符串被插入到每个给定字符串之间,结果作为一个新字符串返回
字典
引子
我们学了列表 , 现在有个需求, 把你们公司每个员工的姓名、年龄、职务、工资存到列表里,你怎么存?
staff_list = [
["Alex",23,"CEO",66000],
["黑姑娘",24,"行政",4000],
["佩奇",26,"讲师",40000],
# [xxx,xx,xx,xxx]
# [xxx,xx,xx,xxx]
# [xxx,xx,xx,xxx]
]
这样存没问题,不过你要查一个人的工资的话, 是不是得把列表遍历一遍
for i in staff_list:
if i[0] == '黑姑娘':
print(i)
break
但假如你公司有2万人,如果你要找的黑姑娘正好在列表末尾,那意味着你要遍历2万次,才能找到这个信息。列表越大,查找速度越慢。
好了,现在福音来了, 接下来学要的字典可以 查询数据又快、操作又方便,是日后开发中必备神器。
字典是Python语言中唯一的映射类型。
定义
{key1:value1,key2:value2}
1、键与值用冒号“:”分开;
2、项与项用逗号“,”分开;
特性:
1.key-value结构
2.key必须为不可变数据类型、必须唯一
3.可存放任意多个value、可修改、可以不唯一
4.无序
5.查询速度快,且不受dict的大小影响,至于为何快?我们学完hash再解释。
创建操作
>>>person = {"name": "alex", 'age': 20}
#或
>>>person = dict(name='seven', age=20)
#或
>>>person = dict({"name": "egon", 'age': 20})
#或
>>> {}.fromkeys([1,2,3,4,5,6,7,8],100)
{1: 100, 2: 100, 3: 100, 4: 100, 5: 100, 6: 100, 7: 100, 8: 100}
增加操作
ames = {
"alex": [23, "CEO", 66000],
"黑姑娘": [24, "行政", 4000],
}
# 新增k
names["佩奇"] = [26, "讲师", 40000]
names.setdefault("oldboy",[50,"boss",100000]) # D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D
删除操作
names.pop("alex") # 删除指定key
names.popitem() # 随便删除1个key
del names["oldboy"] # 删除指定key,同pop方法
names.clear() # 清空dict
修改操作
dic['key'] = 'new_value',如果key在字典中存在,'new_value'将会替代原来的value值;
dic.update(dic2) 将字典dic2的键值对添加到字典dic中
查看操作
dic['key'] #返回字典中key对应的值,若key不存在字典中,则报错;
dic.get(key, default = None)#返回字典中key对应的值,若key不存在字典中,则返回default的值(default默认为None)
'key' in dic #若存在则返回True,没有则返回False
dic.keys() 返回一个包含字典所有KEY的列表;
dic.values() 返回一个包含字典所有value的列表;
dic.items() 返回一个包含所有(键,值)元组的列表;
循环
1、for k in dic.keys()
2、for k,v in dic.items()
3、for k in dic # 推荐用这种,效率速度最快
info = {
"name":"小猿圈",
"mission": "帮一千万极客高效学编程",
"website": "http://apeland.com"
}
for k in info:
print(k,info[k])
输出
name 小猿圈
mission 帮一千万极客高效学编程
website http://apeland.com
练习题
1.用你能想到的最少的代码生成一个包含100个key的字典,每个value的值不能一样
2.{‘k0’: 0, ‘k1’: 1, ‘k2’: 2, ‘k3’: 3, ‘k4’: 4, ‘k5’: 5, ‘k6’: 6, ‘k7’: 7, ‘k8’: 8, ‘k9’: 9} 请把这个dict中key大于5的值value打印出来。
3.把题2中value是偶数的统一改成-1
4.请设计一个dict, 存储你们公司每个人的信息, 信息包含至少姓名、年龄、电话、职位、工资,并提供一个简单的查找接口,
用户按你的要求输入要查找的人,你的程序把查到的信息打印出来
1 #1.用你能想到的最少的代码生成一个包含100个key的字典,每个value的值不能一样
2 #count = 1
3 #dic = {}
4 #while count <= 100:
5 #dic[count] = "Value%d"%count
6 #count+=1
7 #print(dic)
8 #2.{‘k0’: 0, ‘k1’: 1, ‘k2’: 2, ‘k3’: 3, ‘k4’: 4, ‘k5’: 5, ‘k6’: 6, ‘k7’: 7, ‘k8’: 8, ‘k9’: 9}
9 #请把这个dict中key大于5的值value打印出来。
10 #dic = {"k0": 0, "k1": 1, "k2": 2, "k3": 3, "k4": 4, "k5": 5, "k6": 6, "k7": 7, "k8": 8, "k9": 9}
11 #for i in dic:
12 #if int(i[1]) > 5:
13 #print(dic[i])
14 #3.把题2中value是偶数的统一改成-1
15 #dic = {"k0": 0, "k1": 1, "k2": 2, "k3": 3, "k4": 4, "k5": 5, "k6": 6, "k7": 7, "k8": 8, "k9": 9}
16 #for i in dic:
17 #if dic[i] % 2 == 0:
18 #dic[i] = -1
19 #print(dic)
20 #4.请设计一个dict, 存储你们公司每个人的信息, 信息包含至少姓名、年龄、电话、职位、工资,并提供一个简单的查找接口,
21 #用户按你的要求输入要查找的人,你的程序把查到的信息打印出来
22 #dic = {1:{"name":"Yan","age":18,"phone":1388888888,"job":"A","salary":20000},
23 #2:{"name":"YanYun","age":3,"phone":1388888555,"job":"B","salary":20000},
24 #}
25 #info = int(input("请输入你要查找的人的工号:"))
26 #for i in dic:
27 #if info == i:
28 #print(dic[i])
参考答案
集合
定义
集合跟我们学的列表有点像,也是可以存一堆数据,不过它有几个独特的特点,令其在整个Python语言中占有一席之地,
1.里面的元素不可变,代表你不能存一个list、dict 在集合里,字符串、数字、元组等不可变类型可以存
2.天生去重,在集合里没办法存重复的元素
3.无序,不像列表一样通过索引来标记在列表中的位置 ,元素是无序的,集合中的元素没有先后之分,如集合{3,4,5}和{3,5,4}算作同一个集合
基于上面的特性,我们可以用集合来干2件事,去重和关系运算
语法:
创建集合
>>> a = {1,2,3,4,2,'alex',3,'rain','alex'}
>>> a
{1, 2, 3, 4, 'alex', 'rain'}
由于它是天生去重的,重复的值你根本存不进去
帮列表去重
帮列表去重最快速的办法是什么? 就是把它转成集合,去重完,再转回列表
>>> b
[1, 2, 3, 4, 2, 'alex', 3, 'rain', 'alex']
>>> set(b)
{1, 2, 3, 4, 'alex', 'rain'}
>>>
>>> b = list(set(b)) #一句代码搞定
>>> b
[1, 2, 3, 4, 'alex', 'rain']
增删改查
>>> a
{1, 2, 3, 4, 'alex', 'rain'}
#新增
>>> a.add('黑姑娘')
#删除discard
>>> a
{2, 3, '黑姑娘', 'alex', 'rain'}
>>> a.discard('rain') #删除一个存在的值
>>> a.discard('rain2') #如果这个值不存在,do nothing.
>>> a
{2, 3, '黑姑娘', 'alex'}
>>>
#随机删除,少用,或特定场景用
>>> a.pop() #删除并返回
1
#删除remove
>>> a.remove(4)
#查
>>> a
{2, 3, '黑姑娘', 'alex', 'rain'}
>>> 'alex' in a
True
#改
呵呵,不能改。。。
集合的关系运算
s_1024 = {"佩奇","老男孩","海峰","马JJ","老村长","黑姑娘","Alex"}
s_pornhub = {"Alex","Egon","Rain","马JJ","Nick","Jack"}
print(s_1024 & s_pornhub) # 交集, elements in both set
print(s_1024 | s_pornhub) # 并集 or 合集
print(s_1024 - s_pornhub) # 差集 , only in 1024
print(s_pornhub - s_1024) # 差集, only in pornhub
print(s_1024 ^ s_pornhub) # 对称差集, 把脚踩2只船的人T出去
两个集合之间一般有三种关系,相交、包含、不相交。在Python中分别用下面的方法判断:
print(s_1024.isdisjoint(s_pornhub)) # 判断2个集合是不是不相交,返回True or False
print(s_1024.issubset(s_pornhub)) # 判断s_1024是不是s_pornhub的子集,返回True or False
print(s_1024.issuperset(s_pornhub)) # 判断s_1024是不是s_pornhub的父集,返回True or False
python中字符串比较是基于字典序的_Python字符串字典集合相关推荐
- python中使用zip函数基于两个列表数据list创建字典dict数据(Create a dictionary by passing the output of zip to dict)
python中使用zip函数基于两个列表数据list创建字典dict数据(Create a dictionary by passing the output of zip to dict) 目录
- python中字符串的两种序号体系_Python字符串 --Python3
Python语言中,字符串是用两个双引号或者单引号括起来的词汇表或多个字符. 1.Python字符串的两种序号体系 反向递减序号:-- -9 -8 -7 -6 -5 -4 -3 -2 -1 正向递增序 ...
- python中等于号可以用is代替_python中字符串比较使用is、==和cmp()总结
经常写 shell 脚本知道,字符串判断可以用 =,!= 数字的判断是 -eq,-ne 等,但是 Python 确不是这样子的. 所以作为慢慢要转换到用 Python 写脚本,这些基本的东西必须要掌握 ...
- python中怎么统计英文字符的个数_python怎样实现字符串中字符分类及个数统计
python怎样实现字符串中字符分类及个数统计 发布时间:2020-11-20 17:31:18 来源:亿速云 阅读:105 作者:小新 小编给大家分享一下python怎样实现字符串中字符分类及个数统 ...
- python中for语句涉及的序列可以是字符串吗_用for循环,可以遍历字符串、列表、元组、字典、数字序列、文件(TXT、excel)。...
[单选题]以上代码输出的结果是( ) if None: print("Hello") [单选题]在循环语句中,_______语句的作用是提前进入下一次循环. [单选题]在循环语句中 ...
- python判断a是否是b的子串_python字符串a为hello,字符串b为#2#lisaend。判断字符串b中是否含有“#2#...
展开全部 原题: 字符串a为"Hello",字符串b为"#2#Lisaend".判断字符串b中是否含有"#2#",如果有,323131333 ...
- python中select模块_基于python select.select模块通信的实例讲解 如何用python写个串口通信的程序...
python socket怎么利用select实现双工通信 方法: Before : 0000000000000000000000000000000000000000 After pack: 0100 ...
- python中一个字符视为长度为1的字符串_【Python】笔试题知识点小结(1)
题目来源:牛客网 今天开始复习巩固一下基础知识点- 蓝色表示题干,红色表示答案,黑色表示知识点. 1.下列代码的运行结果是? print 'a' < 'b' < 'c'True 1)pyt ...
- python中执行linux命令(调用linux命令)_Python调用Linux bash命令
import subprocess as sup # 以下注释很多(为了自己以后不忘), 如果只是想在python中执行Linux命令, 看前5行就够了 # 3.5版本之后官方推荐使用sup.run ...
最新文章
- crontab定时巡检使用
- MapReduce Java API实例-统计单词出现频率
- BZOJ 1293 [SCOI2009]生日礼物
- JavaScript循环定时器的设置和取消
- 移动平台游戏网络重连方案
- 解决deepin微信无法登录
- 业务专题篇:如何用数据评价某次活动?
- unity实现图片轮播效果_Unity3D实现列表拖拽轮播分页滚动功能
- 深度 | 从DevOps到BizDevOps, 研发效能提升的系统方法
- 如何破解 Google Chrome 的隐身模式?
- 数据建模的的参考工具EZDML
- 通过创建制定版本react-native项目解决“Unable to resolve module `AccessibilityInfo` ”的问题...
- 前端之品优购项目(一)
- 学会Zbrush硬表面建模,造出属于自己的机甲模型
- 三维坐标数学计算公式
- 怎样使用菜单栏中的Apple图标在苹果Mac上强制退出应用程序?
- 创业圈的钱都去哪儿了?AI算法正帮Facebook成为大赢家
- 网页尾部footer编写--小技巧
- php自定义微博尾巴,新浪微博怎么自定义小尾巴 新浪微博自定义小尾巴方法
- 红酒类小程序APP开发源码交付
热门文章
- kotlin与java混合开发_使用kotlin和Java混合开发Android项目爬坑记录
- 嵌入式控制器的输入端口设计分析
- 部分ADSL路由器默认帐号密码
- 五年增长50倍,云栖小镇是怎么炼成的?
- 文房四宝之古墨的发展史:墨香悠远,源远流长
- 全球及中国金属PLA(聚乳酸)行业前景调研与未来竞争趋势研究报告2022版
- nyoj284 坦克大战(dijkstra(bfs+优先队列))
- linux 安装cifs,在ubuntu上搭建sambd实现linux的之间的cifs通信
- python 通过ping获取丢包率
- java在FTP服务器创建文件夹,java在ftp服务器上创建文件夹