for循环补充:
for in(X)range(1,10,1)前面一个1表示起始位置,10表示结束位置,后面一个1是步长,步长也可以是负数,但起始位置的数值要比结束位置数值大,逻辑才是正确的,for循环中顾头不顾尾。
数据类型是用来记录事物状态的,而事物的状态是不断变化的(如:一个人年龄的增长(操作int类型) ,单个人名的修改(操作str类型),学生列表中增加学生(操作list类型)等),这意味着我们在开发程序时需要频繁对数据进行操作,为了提升我们的开发效率, python针对这些常用的操作,为每一种数据类型内置了一系列方法。
int 和float
这两个类型都是不可变的,int和float可以将“纯数字的字符串”变成整型数据或者浮点型数据。另外,int还可以进行数制之间的转换,数字类型主要就是用来做数学运算与比较运算,因此数字类型除了与运算符结合使用之外,没有什么其他内置方法
字符串(str)
字符串是用成对的单引号,双引号,三引号引起来具有描述意义的事物状态,str()可以将任意类型的数据转变成字符串
str[0]:字符串的取值,字符串可以按索引取出字符串的值,str[1:6]表示 字符串的切片操作,也就是取出1到5的所有字符,将这一段取出。字符串也可以加步长,表示跳着去。且步长可为负,倒着取
str.split(":",1)以冒号为分隔符将字符串分为几部分组成的列表,我们可以取出其中我们需要的第几段子字符串
len(str)=统计此字符串的长度
in 加not in:成员运算,即查看一个子字符串是否在一个字符串里
字符串的增删改查:
增:join,“:”.join(列表,字典…)将括号里的内容用冒号连接起来,生成字符串
删:str.strip(" ")引号里存放想要删除的内容,strip是从字符串两边删除内容,优先删除左边,左边删不动以后就删右边,中间的内容,strip删不了,lstrip表示只删除字符串左边的内容,rstrip表示删右边的内容
改:replace用新的字符替换字符串中旧的字符
str7 = ‘my name is tony, my age is 18!’ # 将tony的年龄由18岁改成73岁
str7 = str7.replace(‘18’, ‘73’) # 语法:replace(‘旧内容’, ‘新内容’)
可以指定修改的个数
str7 = ‘my name is tony, my age is 18!’
str7 = str7.replace(‘my’, ‘MY’,1) # 只把一个my改为MY
查:lower,upper分别表示查看字符串是否是小写,字符串是否是大写,返回值为布尔类型,isdigit, 判断字符串是否是纯数字组成,返回结果为True或False str8 = ‘5201314’ str8.isdigit()
format的三种方法
他可以指名道姓的对字符串进行传值
name is {name}, my age is {age}!’.format(age=18,name=‘tony’)
类似于%s的用法,传入的值会按照位置与{}一一对应
str4 = ‘my name is {}, my age is {}!’.format(‘tony’, 18)
把format传入的多个值当作一个列表,然后用{索引}取值
str4 = ‘my name is {0}, my age is {1}!’.format(‘tony’, 18)
for (x)in str:将字符串的每个字符输出
了解操作:
find,rfind,index,rindex,count
find:从指定范围内查找子字符串的起始索引,找得到则返回数字1,找不到则返回-1
msg=‘tony say hello’
msg.find(‘o’,1,3) # 在索引为1和2(顾头不顾尾)的字符中查找字符o的索引1
index:同find,但在找不到时会报错
msg.index(‘e’,2,4) # 报错ValueError
rfind与rindex:略
count:统计字符串在大字符串中出现的次数
msg = “hello everyone”
msg.count(‘e’) # 统计字符串e出现的次数4
msg.count(‘e’,1,6) # 字符串e在索引1~5范围内出现的次数1
center,ljust,rjust,zfill
name=‘tony’
name.center(30,’-’) # 总宽度为30,字符串居中显示,不够用-填充
-------------tony-------------
name.ljust(30,’’) # 总宽度为30,字符串左对齐显示,不够用填充
tony**************************
name.rjust(30,’’) # 总宽度为30,字符串右对齐显示,不够用填充
**************************tony
name.zfill(50) # 总宽度为50,字符串右对齐显示,不够用0填充
0000000000000000000000000000000000000000000000tony
expandtabs
name = ‘tony\thello’ # \t表示制表符(tab键)
name
tony hello
name.expandtabs(1) # 修改\t制表符代表的空格数
tony hello
captalize,swapcase,title
captalize:首字母大写
message = ‘hello everyone nice to meet you!’
message.capitalize()
Hello everyone nice to meet you!
swapcase:大小写翻转
message1 = ‘Hi girl, I want make friends with you!’
message1.swapcase()
hI GIRL, i WANT MAKE FRIENDS WITH YOU!
title:每个单词的首字母大写
msg = ‘dear my friend i miss you very much’
msg.title()
Dear My Friend I Miss You Very Much
is数字系列
在python3中
num1 = b’4’ #bytes
num2 = u’4’ #unicode,python3中无需加u就是unicode
num3 = ‘四’ #中文数字
num4 = ‘Ⅳ’ #罗马数字
isdigt:bytes,unicode
num1.isdigit()
True
num2.isdigit()
True
num3.isdigit()
False
num4.isdigit()
False
isdecimal:uncicode(bytes类型无isdecimal方法)
num2.isdecimal()
True
num3.isdecimal()
False
num4.isdecimal()
False
isnumberic:unicode,中文数字,罗马数字(bytes类型无isnumberic方法)
num2.isnumeric()
True
num3.isnumeric()
True
num4.isnumeric()
True
三者不能判断浮点数
num5 = ‘4.3’
num5.isdigit()
False
num5.isdecimal()
False
num5.isnumeric()
False
‘’’
总结:
最常用的是isdigit,可以判断bytes和unicode类型,这也是最常见的数字应用场景
如果要判断中文数字或罗马数字,则需要用到isnumeric。
‘’’
is其他
name = ‘tony123’
name.isalnum() #字符串中既可以包含数字也可以包含字母
True
name.isalpha() #字符串中只包含字母
False
name.isidentifier()
True
name.islower() # 字符串是否是纯小写
True
name.isupper() # 字符串是否是纯大写
False
name.isspace() # 字符串是否全是空格
False
name.istitle() # 字符串中的单词首字母是否都是大写
False
列表定义:在[]内,用逗号分隔开多个任意数据类型的值
l1 = [1,‘a’,[1,2]] # 本质:l1 = list([1,‘a’,[1,2]])
但凡能被for循环遍历的数据类型都可以传给list()转换成列表类型,list()会跟for循环一样遍历出数据类型中包含的每一个元素然后放到列表中
list(‘wdad’) # 结果:[‘w’, ‘d’, ‘a’, ‘d’]
按索引存取值(正向存取+反向存取):即可存也可以取
正向取(从左往右)
my_friends=[‘tony’,‘jason’,‘tom’,4,5]
my_friends[0]
tony
1.2 反向取(负号表示从右往左)
my_friends[-1]
5
对于list来说,既可以按照索引取值,又可以按照索引修改指定位置的值,但如果索引不存在则报错
my_friends = [‘tony’,‘jack’,‘jason’,4,5]
my_friends[1] = ‘martthow’
my_friends
[‘tony’, ‘martthow’, ‘jason’, 4, 5]
切片(顾头不顾尾,步长)
顾头不顾尾:取出索引为0到3的元素
my_friends[0:4]
[‘tony’, ‘jason’, ‘tom’, 4]
长:0:4:2,第三个参数2代表步长,会从0开始,每次累加一个2即可,所以会取出索引0、2的元素
my_friends[0:4:2]
[‘tony’, ‘tom’]
长度
len(my_friends)
5
成员运算in和not in
‘tony’ in my_friends
True
‘xxx’ not in my_friends
True
添加
append()列表尾部追加元素
l1 = [‘a’,‘b’,‘c’]
l1.append(‘d’)
l1
[‘a’, ‘b’, ‘c’, ‘d’]
extend()一次性在列表尾部添加多个元素
l1.extend([‘a’,‘b’,‘c’])
l1
[‘a’, ‘b’, ‘c’, ‘d’, ‘a’, ‘b’, ‘c’]
insert()在指定位置插入元素
l1.insert(0,“first”) # 0表示按索引位置插值
l1
[‘first’, ‘a’, ‘b’, ‘c’, ‘alisa’, ‘a’, ‘b’, ‘c’]
删除
del
l = [11,22,33,44]
del l[2] # 删除索引为2的元素
l
[11,22,44]
pop()默认删除列表最后一个元素,并将删除的值返回,括号内可以通过加索引值来指定删除元素
l = [11,22,33,22,44]
res=l.pop()
res
44
res=l.pop(1)
res
22
remove()括号内指名道姓表示要删除哪个元素,没有返回值
l = [11,22,33,22,44]
res=l.remove(22) # 从左往右查找第一个括号内需要删除的元素
print(res)
None