标签:str tab orm linux typeerror ring for 关键字 方式
目录
内置对象方法汇总
String
定义,切片,长度,替换,编列.....
列表/元组
定义,使用,循环遍历......
字典
定义,使用,循环遍历.......
集合Set
连接数据库!
各种内置模块
os,file,re,time,json.......
字符串是字符串的列表! 可以通过索引访问,索引从0开始,-1表示最后一个
索引不能操作范围!
字符串不可变!
编列
+表示连接: 控制台input()方法输入的内容都是字符串!
切片 [开始:结束:步长] [::-1]倒序
格式化字符串
name = tom
age = 20
print("名字:%s,年龄:%d"%(name,age))
print(f"名字:{name},年龄:{age}")
print("名字:{0}年龄{1}".format(name,age))
转义
\‘ 转义
\t 制表符等于4个空格(Tab)
\n 换行 \r\n linux换行
\ 续行(该行还未结束,下一样继续)
chr()
内置方法
len(字符串) # 长度
chr() 转化为字符 chr(97)--a chr(65)--A
ord(字符)转化为对应ASCII编码 ord(‘A‘)-->65
find(字符) 找不到返回-1
index(字符)找不到报错
replace(‘老字符串‘,‘新字符串‘) 替换
splite(‘字符‘) 拆分 返回列表!
lower(字符串) 转为小写
upper(字符) 转为大写
strip(字符串) 去掉两遍空格 rstrip(字符串) 去掉右边空格 lstrip(字符串)去左边
not in ‘hello‘ 判断是否存在!
s = ‘hello‘
s[0] --->第一个
s[-1] --->最后一个
s = ‘helloWorld‘
s[5] =‘w‘ #报错 str not support item assignment
str01=‘hello‘
for i in hello:
print(i)
for i,v in enumerate(str01):
print(f‘第{i},个值:{v}‘)
print(chr(random.choice(range(97,123))))
print(chr(random.choice(range(65,91))))
image-20201030155819095
常见的序列类型
列表 list. 可变
元组 tuple
范围 range
image-20201031142639473
方法介绍
方法 说明
len(列表) 列表长度
列表名[i] 根据索引找 list01[-1] 最后一个
列表名[开始,介绍,步长] 切片
list01 = ‘hello‘
print(list01[0])
print(list01[-1])
print(list01[len(list01)-1])
print(len(list01))
print(list01[0,3]) #前2个!
list01= [1,2,3,4,5]
print(list01[2,4]) # 结果3,4
print(list01[-4,-1]) # 不包含-1位置的! 从-4位置开始,2往后取 -->2,3,4
list01= [‘A‘,‘B‘]
list02= [1,2]
print(list01+list02)# ===>[‘A‘,‘B‘,1,2] 必须都是列表!
list01= [1,2,3]
list02 = [i+3 for i in list01]
print(list01) # 4,5,6
list01= [1,3,5]
list01[0]= 10 #替换一个
list01[::] = [4,6,9] # 替换
print(list01)# 4,6,9
list01=[1,2,3]
list02=[4,5.6]
list01.extend(list02) #===> [1,2,3,4,5,6] 扩充原列表!
元组不能修改!
创建
t1 = (1,2,3) # 语法1 常用!
t2 = tuple(1,2,3) # 语法2
t2 = tuple([1,2,3,3]) # 语法3
不能重新赋值
t1 = (12,13,35)
t1[0]=3
TypeError: ‘tuple‘ object does not support item assignment # 元组项不支持重新赋值!
不能删除元素!
字符串,列表,元祖转化
range(开始,结束,步长
for i in range(0,10): # range 返回的数据类型
print(i) #0到9
4.字典和集合
字典存储成对存在数据! {key1:value1, k2:v2,.....}
集合: 无序,不重复!
基本语法: {key1:value,key2:value,....}
列表和字典区别
key是字符串或数值! key是不可变类型!
key不能重复! 重复会自动覆盖!
增加/修改
d1 = {}
d1[‘name‘]=‘张三‘ #增加
d1[‘age‘]=20 # 增加
d1[‘name‘]=‘小A‘ # 修改!
字典推倒式/列表推倒式
d1 = {x:x**2 for i in (1,2,3)}
取值: 字典[‘key‘] 或 字典.get(key)
判断key是否存在!! ‘python2.x中 has_key(key)‘
d2= {‘name‘: ‘AA‘, ‘age‘:20}
if ‘sex‘ in d2:
print(‘存在‘)
for...in 遍历
d1 ={‘name‘:‘张三‘,‘age‘:20,‘sex‘:‘男‘}
# keys()获取所有键 values()所有值
for k in d1.keys():
print(f‘名字{k},值:{d1[k]}‘)
print(d1.values())
print(d1.items())
# 同时编列key,value
for k,v in d1.items():
print(f‘名字{k},值:{v}‘)
删除: del 字典/字典[key]
清空 保留存储空间,clear()
删除pop(key)
更新一项update({key:value})
题目list排重!: 删除某个list中的重复项? [1,20,22,31,423,1,......]
image-20201102163134289
li = [1,1,5,5,8,8]
set(li)===>搞定!
作业: 测试两个方法效率? 数据量大时排重效率高的方法!
Set: 可变集合
frozenset : 不可变集合
创建
s1 = {1,2,3,3} # 结果 (1,2,3)
s2= set([1,2,3])
s3= frozenset([1,2,3])
编列
s1 ={‘a‘,‘b‘,‘c‘}
for i in s1:
....
是否存在: in/not in
增加集合.add(元素)
删除集合.remove(元素) 集合.clear()清空 集合.pop()
删除 -=
s1 = {5,‘h‘,‘a‘}
s2 = set(‘hai‘) # {"h","a","i"}
s1 -= s2 # s1 = s1-s2 #只减去共有的!
print(s1) # 结果 5
zhangsan = {1,2,3,5,7,8} # 答对6道
lisi = {5,7,8,9,10} # 答对5道
zhagnsan -=lisi
lisi -=zhangsan
删除所有del 集合名
集合运算
和 < 判断范围!
s1 = set(‘What‘)
s2 = set(‘hat‘)
print(s1>s2) #成立!True
标签:str tab orm linux typeerror ring for 关键字 方式
原文地址:https://www.cnblogs.com/ls98/p/13919860.html