昨日补充:
1.在代码的编写中,总会有一些分支编写不出来,为了不影响整个系统的跑动,可以使用pass关键字进行跳过。如
count=0 while count<10: if count<5: print(count) count+=1 else: pass
如果正常情况下else中的语句不写而开始运行时,会报错,通过pass可以使程序正常的跑起来。
2.在range的使用中,可以通过第三参数进行步长定义,如
for i in range (1,10,2): print(i)
当步长设置为2时,i会成2倍迭代,使得原本输出的1-9 变成输出1-9的奇数。
今日内容
1.数据类型的用途,定义方法与常用函数操作。
1.整型(int)
用途:存整型数组,定义手机号qq号,身份证号等等。
定义方法:
age=18 #age=(int)18
这种数据类型的转换只在可转的范围内进行转换,像浮点型就不能向整型转化,这与c语言中有很大的不同:
a=int('123412') b=int(23.12)
像a中会输出int类型的123412,b则会报错,当字符串中出现了非数字,或浮点型的数字时也会报错。
进制转化函数:
十进制转化成二进制
d=bin(12) #>>>ob1100 #ob后面表示后面的数字是二进制
十进制转化成八进制
d=oct(12) #>>>Oo14 #Oo后面表示八进制数
十进制转化成十六进制
d=Hex(12) #>>>Oxc #Ox后面表示的数十六进制
二进制,八进制,十六进制转化成十进制
print(int('10',2)) print(int('20',8)) print(int('20',16))
最后结果输出为‘2,16,32”,所以第二参数代表的是进制数,而第一参数所传递的值必须是以字符串形式。
2.浮点型:
作用:记录带有小数电的数据,如身高,体重等,比较精确。
定义方法:
a=3.14 #a=float(3.14)
浮点型数据的字符串也可转换为浮点型。
3.字符串:
用途:具有描述性的数据类型。
定义方法:
str1='我是字符串1' str2="我是字符串2" str3='''我是字符串3'''
以上三种都可以定义字符串。
【1】按索引取值(正向取值和反向取值)
str1="abcdefg" print(str1[1],str1[-1])
在上述代码中,分别用正向取值和反向取值,取得的值风别为”b“和”g“
【2】切片
在字符串的操作中,可以取一个字符串的其中一段字符,如
str1="abcdefg" print(str1[0:5:1])
上述代码运行结果为”abcde“,0-5表示其取字符串的区间,1表示步长,即以每1个字符输出1个字符。
在切片中,其可切方向可以是从右往左的,只要将区间从右往左设置,步长设置成向左遍历的负数即可,举个例子:
str1="abcdefg" print(str1[6:0:-2])
区间从6到1(左开右闭),步长为-2,其输出 结果应该是gec
【3】长度
用途:统计字符串中的字符的个数。
str1='我是字符串'
print(len(str1))
运行结果为5,也就是字符串中的符号个数。
【4】成员运算
用途:判断一串字符串中是是否有相应的字符串:
print('lzx' in 'my name is lzx') print('lzx' not in 'my name is lzx')
第一个输出的是lzx是否在后面的字符中出现,运行结果显然是true,第二个输出的是lzx是不是不在后面的字符串,运行结果是false。
【5】strip()
用途:去掉字符串中两边的空格,保留中间的字符。
str3=' 222 i am iron man 22222 ' print(str3.strip()) print(str3.strip(' 2 '))
第一个输出的是连带2的字符串,默认的五给定值的strip函数是将两边的空格去除,而当给定了一些值后,就会根据内外去掉字符串两边的字符。
在去除中时,python只会从外到内依次识别字符,如果中间有字符挡住了,不会越过该字符,去除工作也到此为止。例:
str1='!?<1314<?!' str2='!?<1314<?}!' print(str1.strip('!?<'),str2.strip('!?<'))
str1完全清楚了多余的字符,而str2在去时被}符号挡住了,所以之前的全部不会识别到,算作中间字符。
rstrip(),lstrip()分别为有清除与左清除,即在字符串的左右清除。
str1='!?<1314<?!' str2='!?<1314<?!' print(str1.lstrip('!?<')) print(str1.rstrip('!?<'))
#1314<?!
#!?<1314
结果一个去除了左边符号,一个去除了右边符号。
【6】split()
用途:用于按符号切分字符串,最终以列表的形式输出。例:
str1='www.baidu.com' list1=str1.split(".") print(list1) #>>>['www', 'baidu', 'com']
可以看split中的参数其实是对字符串按照什么符号进行分割,而输出的是列表。如果需要切割部分字符串,需要对其第二参数进行设置:
str1='www.baidu.com' list2=str1.split('.',1) print(list2)
最后输出的结果是['www', 'baidu.com'],只对字符串进行了1次分割。
rsplit.(),是将字符串从右到左分割,如果未选择指定分割次数,rsplit和split的效果是一样的。
【7】循环
使用for循环对字符串进依次赋值:
for i in '我叫lzx,来自江苏': print(i) #输出结果 # 我 # 叫 # l # z # x # , # 来 # 自 # 江 # 苏
需要掌握的:
【1】strip,lstrip,rstrip
【2】lower,upper
用途:分别代表将字符串中全部小写,和全部大写
str2='i AM lZX,I love sTAkinG' print(str2.lower()) print(str2.upper()) #输出结果>>> i am lzx,i love staking I AM LZX,I LOVE STAKING
【3】startswith,endswith
用途:分别代表判断字符串是否以某个字母开始和结束。例:
str2='i AM lZX,I love sTAkinG' print(str2.startswith('i')) print(str2.endswith('i')) #>>>输出结果 True False
【4】format(),三种占位方法:
用途,相当于占位符。
1.按位置占位。
str1="my name is {},my age is {}".format('lzx',18) print(str1)
#输出结果
>>>my name is lzx,my age is 18
这种占位方式与%占位符一样的占位方法。
2.按索引占位
str1="my name is {0},my age is {1},{1},{1}".format('lzx',18) print(str1) #输入结果 >>>my name is lzx,my age is 18,18,18
占位符中的数字代表的是format函数中列表相对应的数据,将其填入字符串中。
3.关键字传参(指名道姓占位)
str1="my name is {name},my age is {age},{age},{age}".format(name='lzx',age=18) print(str1) #输入结果 >>>my name is lzx,my age is 18,18,18
在占位符中输入关键字,再再后面的列表中寻找关键字中的值作为参数传递到字符串中,这种类似对 字典的索引方式叫关键字传参。
【5】split,rsplit
【6】join拼接
这是一个字符串的操作,是用这个字符串拼接一个列表。
list4=['12','123','412','123','21','12'] str1='!'.join(list4) print(str1)
输出结果>>>
12!123!412!123!21!12
这里注意的是,被操作的列表其元素也需要是字符串类型,否则会报错。
【7】replace()换
用途:将字符串中的某个字符替换成另一个。
str2='my name is lzx ,l am from taizhou' print(str2.replace('lzx','yzy'))
【8】isdigit()
用途:判断字符中包含的是否为纯数字。
str2='my name is lzx ,l am from taizhou' print(str2.isdigit()) #输出结果 >>>False
需要了解的内置方法
1.find,rfind
用途:索引字符串里是否包含某个字符,,如果找到了,则返回它所在的位置,如果不存在,则返回-1.
str2='hello my name is lzx i am fine thankyou' print(str2.find('my'),str2.find('your')) print(str2.find('o',2,10)) #输出结果>>>6 -1 #4
当给这个函数一个区间后就会在这个区间里检索存在与否。
2.index,rindex
与find用法一样,不同的是当它未检索到值时会报错
str2='hello my name is lzx i am fine thankyou' print(str2.index('my'),str2.index('you')) print(str2.index('o',2,10)) #输出结果>>>6 36 4
3.count
用途:统计字符出现的个数
str2='hello my name is lzx i am fine thankyou' print(str2.count('i')) #输出结果>>>3
4.center,ljust,rjust,zfill
str1='s1' str2='s2' str3='s3' str4='s4' print(str1.center(20,'*')) print(str2.ljust(20,'*')) print(str3.rjust(20,'*')) print(str4.zfill(20)) #输出结果>>> # *********s1********* # s2****************** # ******************s3 # 000000000000000000s4
center(),将字符串剧中,其余部分用符号填上。
ljust()将字符串左对齐,其余用符号填上。
rjust()将字符串右对齐,其余用符号填上。
zfill()将字符右对齐,其余用‘0’填上。
3.expandtabs
用途:将字符串中的\t转换成空格
str5='adl\tad' print(str5) print(str5.expandtabs(8)) #输出结果: adl ad adl ad
4.captalize ,swapcase(),title()
str2='helLO woRLd' print(str2.capitalize()) print(str2.swapcase()) print(str2.title()) #输出结果 #Hello world #HELlo WOrlD #Hello World
captalize():字符串的首字母大写。
swapcase():字符串大小写互换。
title():字符串中每个单词首字母大写。
5.is数字系列
isnumber(),isdecimal(),isdigit(),
num1=b'4' #bytes
num2=u'4' #unicode,python3中无需加u就是unicode
num3='壹' #中文数字
num4='Ⅳ' #罗马数字
# ''.isnumeric(): unicode,中文数字,罗马数字 只要是表示数字都识别
print(num2.isnumeric())
print(num3.isnumeric())
print(num4.isnumeric())
# ''.isdecimal(): unicode 只识别普通的阿拉伯数字
print(num2.isdecimal())
print(num3.isdecimal())
print(num4.isdecimal())
# ''.isdigit() :bytes,unicode 通常情况下使用isdigit就已经满足需求了
print(num1.isdigit())
print(num2.isdigit())
print(num3.isdigit())
print(num4.isdigit())
二、列表(list)
list的内部原理就是for循环。
优先掌握的操作
【1】按索引取值
list1=[1,2,3,4,5] print(list1[0:5:2]) print(list1[0::]) #输出结果>>>[1, 3, 5] #[1, 2, 3, 4, 5]
如同切片一样。
【2】切片,如上
【3】长度
list1=[1,2,3,4,5,6] print(len(list1)) #输出结果>>>6
【4】成员运算
in和not in
list1=[1,2,3,4,5] print(444 in list1)
在list1中检索444是否在。
【5】往列表中添加元素
1.append()
用途:在尾部位置添加元素。
list1=[1,2,3,4,5] list1.append("4") print(list1)
最后输出[1, 2, 3, 4, 5, '4']
2.insert()
用途:通过检索在任意位置添加元素。
list1=[1,2,3,4,5] list1.insert(2,'20') print(list1) #输出结果为>>>[1, 2, '20', 3, 4, 5]
3.extend()
用途:将其中的元素变成列表添加至最后。
其中list必须是list类
list1=[1,2,3,4,5] list1.extend([1,2,3]) print(list1) #输出结果为>>>[1, 2, 3, 4, 5, 1, 2, 3]
6.删除
1.del list[x],删除list中的x位置的数据。
del适用于所有类型的数据。
2.list.pop() 从尾部依次弹出
list2=[1,2,3,4,5,6,7,8] a=list2.pop() print(a) #输出结果>>>8
弹出的值可以被作为最后一次利用。除此之外还可以索引后弹出相应的数据
list2=[1,2,3,4,5,6,7,8] a=list2.pop(2) print(a) #输出结果>>>3
7.remove(a) 删除啊,所在的数据
此删除pop不同的是remove不能再次对数据进行利用。
list2=[1,2,3,4,5,6,7,8] list2.remove(2) print(list2) #输出结果>>>[1, 3, 4, 5, 6, 7, 8]
8,列表的循环
for i in list2: print(i) #输出结果: # 1 # 2 # 3 # 4 # 5 # 6 # 7 # 8