一.常用的字符串方法

capitalize() #将字符串首字母大写

center(100,'*') #把字符串居中的

count(‘zhou’)#查询次数

endswith('.jpg ')#判断字符串是否以XXX结尾;返回类型为布尔类型,True 或者False

startswith(‘138’)#判断字符串是否以xxx开头

upper()#都给你变成大写

lower()#都给你变成小写

find(‘a’)#找字符串的下标,找不到不会报错,返回-1

index(‘a’)#找字符串的下标,找不到会报错

isdigit()# 判断是否为纯数字

isspace()#判断是否全是空格

isalnum()#只能有英文或数字

isalpha()只能有英文、汉字

strip()#去掉字符串两边的东西,默认是去掉两边的空格和换行符的

lstrip()#只去掉左边的

rstrip()#只去掉右边的

replace(‘123’,‘456’)#替换字符串,把前面的替换成后面的,第三个参数是替换的处数,默认替换全部

istitle()#标题,首字母为大写即标题

zfill()# 在前面补0

eg:name ='5'

print(name.zfill(2)

结果 05

split(‘,’)#1.分割字符串 2.把字符串变成一个list 3.默认是以空格和换行符分割的

join()#1.把list变成字符串的 2.以某个字符串连接

二、 切片、循环list

1.循环list、循环字符串同

eg:stus = ['abc','tzy','nihao']

for stu in stus:

print(stu)

2.切片,list取值的一种方式

stus = ['abc','tzy','nihao']

stus[1:2]#顾头不顾尾,能取到‘tzy’,取不到‘nihao’

stus[:3]#从头开始可不写

stus[1:]#如果后面的下标不写的话,代表取到结尾

stus[:]#开头的下标和结尾的下标都不写,代表取到整个list

stus[-1]#-1代表最后一个元素

eg:import string

string.digits.split()

结果:['0123456']

nums = list(string.digits)

print(nums)

结果:['0','1','2','3','4','5','6','7','8','9']

print(nums[0:11:2])#第二冒号后面值代表步长,是隔几个元素取一次

结果:['0','2','4','6','8']

print(nums[::-1])#步数是负数从右往左开始取值,反转

print(nums[1:5:-1])

print(nums[-6:-10:-1])

#切片同样适用于字符

3.元组

#元组 list 但它不可变 一旦定义好就不能再变
cities = ('beijing','shanghai')
#元组取值,取下标
print(cities[0])
print(cities.count('beijing'))#数出现的次数
print(cities.index('beijing'))#取下标
#字符串定义好后,也不能修改,只能重定义

eg:s='abcEFGabc'

s = s.replace('abc','')

print(s)

结果:EFG

三、list循环删元素、变量存储方式

eg:
a=[1,1,2,3,4,5,6,72]
b=[1,1,2,3,4,5,6,72]
#  0 1 2 3 4 5 6 7
[1,2,3,4,5,6,72]
for i in b:#i是list里的元素
if i%2!=0:
a.remove(i)
print(a)

结果:[1,2,4,6,72]

原因:下标错乱

解决办法:再定义一个一模一样的list,循环一个list,删另一个list

b=a[:]

print(id(a)# 打印a的内存地址

a=b=c=d=0

e,f,g=1,2,3

a,b=1,2 #交换a、b的值

b,a=a,b#python中可以直接交换,自动引入了第三方变量

四、字典

1.非空即真,非0即真

eg:

a1=1

b1=2

print(a1==b1)

结果:False

a=[]

b=''

c=()

d=0

e=None

if a: #如果a有值

print('是真的')

else:

print('是假的')

结果:是假的

import this #python的话

#not的意思是取反

m=‘好’

print(not m)

结果:False

2.字典

# k - v

d = {}

zjr={‘name‘’:‘zhoujirong’,

‘age‘:‘18’,

‘sex’:‘女’,

‘qq’:‘13242452’}

#字典的k唯一,相同k会取最后一个

#字典是无序的

#增加

zjr['身高’]=’165'

#修改

zjr['age']=35#有的话就改,无的话加

zjr.setdefault('age',50)#如果key已经存在,就不会修改,若不存在,加

#删除

zjr.pop('qq')#指定key删掉,key不存在会报错

del zjr['age']#del删除,key不存在会报错

zjr.clear()#清空字典

zjr.popitem()#随机删除一个key

#取值

zjr['name']#不存在会报错

zjr.get('email','[email protected]')#key不存在返回None,第二个参数是若值为空取默认

‘age’ in data:  #判断data字典里是否有‘age’这个key

tzy={'name1':'pig','age':20}
zjr.update(tzy)#把一个字典加入另一个字典里面
print(zjr.values())
print(zjr.keys()) for i in zjr:
print(i)#循环打印的是字典的key
for k,v in zjr.items():
print(k,v) #能同时取到key和value
print(zjr)

高效循环字典的方式

d = {'a':1,'b':2}
print(d.items())
for k,v in d.items():
print(k,v)
for k in d:
print(k,d.get(k))
#记录学生是否交作业的小程序
#学生名字 日期 状态
data ={
'zjr':{
'2018-6-3':'未交'
},
'pig':{
'2018-6-7':'已交'
}
} for i in range(2): name =input('name:').strip()
date = input('date:').strip()
status = input('status'.strip())#可以不写,如果不写的话,是未交
if name and date:# 判空,如果name和date都不为空,状态为空时默认为未交
status = '已交' if status else '未交'#三元表达式
if name in data:
data[name][date]=status
else:
tmp = {date:status}#{'2018-2-3':'未交'},#data[name]= {date:status}先构造一个小字典
data[name]=tmp#再给外面这个大字典加一个学生 value这个小字典
print('添加之后的',data) else:
print('姓名和日期不能为空!')

#注意:

status = '已交' if status else '未交' #三元表达式
#上面的一行和下面的四行是一样的
if status:
status = '已交'
else:
status = '未交'

五、文件读写

1.打开文件
#2.对他读或写
#3.关闭文件 #open() file()
#1.有没有清空内容
#2.能不能读到东西
#3.文件不存在会不会报错
f = open(r'C:\Users\Mezhou\PycharmProjects\untitled\zjr','a+',encoding='utf-8') #写路径之前加r,当前目录直接写文件名
# print(f.read())
#文件指针
# print('readline',f.readline())#读取文件一行的数据 # names = ['abc','zjr','tzy','hdhsh']
# for name in names:
# f.write(name+'\n')
# f.writelines(names)#传一个list,然后把list里面的每一个元素写入到文件中
f.seek(0)
print('readlines',f.readlines())#获取文件里面的所有内容,每一行的数据放到一个list里面
# print('read',f.read())#获取文件里的所有内容
#f.write('789') # f.seek(0)#移动文件指针到最前面
# print('read',f.read())
# f.close() #只读模式 r 读写模式 r+
#只能读 文件不存在会报错 可读可写,打开不存在的时候也会报错 #写模式 w
#会覆盖以前文件里的内容,不能读 文件不存在的话,会帮你创建一个
#写读模式 w+ 会清空以前的数据
#只要粘上r,文件不存在就会报错
#只要粘上w,文件内容肯定会被清空 #追加模式 a+
#能读、能写、不会清空以前的内容,文件不存在会创建 # print(f.read())
# names =['a','a1','g3']
# for i in names:
# f.write(names+'\n')
05-11 13:09