2018-08-22 day3 python基础语法(二)字符串
1.字符串
a='asdha'
str1='''sdlja
asdajslkda
sadlskjd
lgjsdf
'''
a.说明
python中没有字符类型,如果要表示字符,就要用一个长度是1的字符串表示。长度:指的就是长度字符串中字符的个数(tab和空格和换行都算一个)
b.转义字符
1.通过 \ 将一些特殊的字符转换成一个具有特殊功能或者特殊意义的字符,就是转义字符.
2.常见的转义: \n (换行),\t (tab), \\(\),\'(')
a1='ajhds\nasd'
a2='asdsad\tsad'
a3='awdwd\\asdsa'
ajhds
asd #a1
asdsad sad #a2
awdwd\asdsa #a3
在计算机字符串长度的时候,转义字符的长度是1
3.字符串前加r,str里面全部转义(无意义)
a=r'ashd\\/\/\t\n/\/\/'
ashd\\/\/\t\n/\/\/ #a
c.编码
1.python中字符的编码采用的是Unicode编码。
a.将字符转换成制定的数值,这个过程就是编码。(方便计算机存储)
b.将数值转换成对应的符号的过程就是解码(反编码)
c.Unicode采用两个字节(8位 ,2^15个),能够将世界上所有的符号进行编码。(包含了ASCII码)
d.python中的编码(chr())
1.将Unicode码转换成字符
print(chr(0xFB22)) # ﬢ(结果)
2.将字符转化成Unicode编码(ord())
print(hex(ord('唐'))) # 0x5510
2.获取字符
a.字符串实质:
可以看成是一个不可变的序列,序列内容是字符。一旦字符串确定,字符串里面的内容和位置是不可变的。
1.获取单个字符,通过下标(索引)来获取指定位置上的字符
str1='asojdl' # 取出第三个字符
print(str1[2]) #结果是o
索引:
a.0~字符串长度减一(不能越界)
b.-1~负字符串长度(不能越界)
str1='asojdl' # 取出第三个字符
print(str1[-4]) #结果是o
2.获取多个字符(切片)
a.切边可以越界,取临界值
字符串[下标1:下标2]:从下标1开始,获取到下标2千的所有的字符,(从下标1开始,每次下标值加1,一直加到下标2前,下标1对应的位置,一定要在下标2对应的位置前)
str1='asojdl' # 取出第二
print(str1[1:3]) #结果是s o
print(str1[[1:-4]) # 结果是s
b.字符串[下标1:下标2:步进]
从下标1开始取,取到下标2 每次下标值加步进
a='iwjdawdjkasj'
print(a[::2]) # 结果 ijadks
注意:a.步进如果是正数,那么下标1对应字符的位置在下标2字符对应位置的前面,如果步进是负数,那么下标1对应的位置在下标2对应的位置的后面。b.下标2对应的字符是取不到的,即区间是前闭后开[下标1,下标2)
c.切片索引省略
a='sdalksjdla'
print(a[::]) #sdalksjdla
1.下标1省略默认是开始的位置(步进正则是字符第一个字符开始,步进负则是字符最后一个字符开始)
2.下标2省略:下标1位置开始要结束(同上相反,即步进正则到结束位置,步进负则到开始位置)
3.字符串的相关运算
a.字符串的加运算(必须两个字符串相加)
b.字符串的乘法运算(字符串*正数)
c.支持所有的比较运算符(大小比较是比较Unicode编码的大小依次比较)
print('abc'+'aas') # 结果abcaas
print('asd'*2) # 结果asdasd
print('abc' == 'abc') # True
print('abc' != 'abc') # False
print('abcf' > 'ac') # False
#(a=a,b<c 所以ac>abcf)
4.in 和not in
a.用法:in 和not in的结果想法
str1 in str2(str1是否在str2中)
b.获取字符串长度( len() 方法)
print('as' in 'sasdwdw') # True
print('as' in 'a1ssdwa') #False
print('as' not in 'sasdwdw') # False
print('as' not in 'a1ssdwa') #True
print(len('askdwakdjwa')) # 11
5.空串
str1=''
str2='' ''
print(len(str1)) # 0
print(len(str2)) #0
6.阻止转义
print(r'sajdh\/\/\t\n\t\t') # sajdh\/\/\t\n\t\t
print(R'sajdh\/\/\t\n\t\t') # sajdh\/\/\t\n\t\t
#练习
str1=r'\nabc123' #str1[3]
str2='abc123\\123' #求str2[-5]
print(str1[3]) #b
print(str2[-5]) #3
6.字符串的相关方法(内置函数)
基本上都是:字符串.函数() or 函数(字符串),这些所有函数的功能都不会影响原来的字符串,而是生成一个新的字符串(字符串不可变)
1.capitalize()
2.center(width,fillchar) # width:输入位置的宽度。fillchar:剩余
没有占得位置用什么填充
3.rjust(width,fillchar) #让字符串变成width对应的长度,原内容靠右,剩余的部分使用fillchar来填充
4.count(str) 判断str在原字符串中的出现的次数
5.字符串.join(str2)
6.字符串.resplace(old,new)
str1='sadasd'
number='1'
print(str1.capitalize()) # 将首字母大写
print(str1.center(20,'t')) #tttttttsadasdttttttt
print(str1.center(20,' ')) # sadasd
print(number.rjust(3,0)) # 001
print(str1.count(a)) # 2
print(str1.join('ww')) #wsadasdw
print(str1.replace('a','x')) #sxdxsd
7.格式化
a.'格式符' %(格式符对应的值)
b.常见格式符
%s--->字符串
%d--->整数
%f--->浮点数 %.nf---->保留多少位
%c--->字符
first_name = '唐'
last_name = '小富'
print('我的姓是%s,我的名是%s' %(first_name,last_name))
#我的姓是唐,我的名是小富
print('我的名字是{0}{1}'.format(first_name,last_name))
#我的名字是唐小富
money = 100
print('%f元' %money) # 100.000000
print('%.2f' %money) # 100.00
char_code = 99
print('%d对应的code码是%c' % (char_code,char_code)) # 99对应的code码是c
print('%d格式化八进制0o%o,十六进制0x%x' % (char_code,char_code,char_code)) #99格式化八进制0o143,十六进制0x63
8.数据类型的转换
a.整数+浮点数------->浮点数
b.整数+布尔---------->整数{True(1),False(0)}
c.强制转换:
语法----------> 类型名(需要转换的数据)
例如: int(19.5)----->19
1.str---->int (str去掉引号是int就可以转换)
2.bool,str---->float (str去掉字符引号后是int或者float)
3.其他类型转化成bool
结论:所有的数据类型都可以转换成bool
1.数字中除了0是False,其它都是True
2.字符串中除了空串是False,其他的都是True
总结:所有为空,0的值全部都是False
print(bool(0))
print(bool(''))
print(bool(""))
print(bool(None))
'''
False
False
False
False
'''
作业
在做下面的每个练习时,都编写一个独立的程序,并将其保存为名称类似于name_cases.py的文件
2-3 个性化消息: 将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,如“Hello Eric, would you like to learn some Python today?”。
#txf_2-3.py
user_name='txf'
print('“Hello '+user_name+',would you like to learn some Python today?”')
'''
结果:“Hello txf,would you like to learn some Python today?”
'''
2-4 调整名字的大小写: 将一个人名存储到一个变量中,再以小写、大写和首字母大写的方式显示这个人名。
#txf_2.4.py
user_name='txf'
print(user_name) #小写
print(user_name.upper()) #大写
user_name_lower=user_name.upper()
print(user_name_lower.lower()) #大写变成小写
print(user_name.capitalize()) #首字母大写
'''
结果:
txf
TXF
txf
Txf
'''
2-5 名言: 找一句你钦佩的名人说的名言,将这个名人的姓名和他的名言打印出来。输出应类似于下面这样(包括引号):Albert Einstein once said, “A person who never made a mistake never tried anything new.”
#txf_2.5.py
user_name='woyebuzhidao'
print('"life is short,I use python."\n')
print(' '*12+'-------'+user_name)
'''
结果:
"life is short,I use python."
-------woyebuzhidao
'''
2-6 名言2: 重复练习2-5,但将名人的姓名存储在变量famous_person 中,再创建要显示的消息,并将其存储在变量message 中,然后打印这条消息。
#txf_2.6.py
famous_person='woyebuzhidao'
message='Life is short,I use python'
print(message+'\n'+' '*12+'-------'+famous_person)
'''
结果:
Life is short,I use python
-------woyebuzhidao
'''
2-7 剔除人名中的空白: 存储一个人名,并在其开头和末尾都包含一些空白字符。务必至少使用字符组合"\t" 和"\n" 各一次。 打印这个人名,以显示其开头和末尾的空白。然后,分别使用剔除函数lstrip() 、rstrip() 和strip() 对人名进行处理,并将结果打印出来。
#txf_2.7.py
user_name=' woyebuzhidao '
print("1显示\n空格"+user_name+"显示\t空格")
print("2显示\n空格"+user_name.strip()+"显示\t空格") #去除开头和结尾的空格
print("3显示\n空格"+user_name.lstrip()+"显示\t空格") #去除开头的空格
print("4显示\n空格"+user_name.rstrip()+"显示\t空格") #去除结尾的空格
'''
结果:
1显示
空格 woyebuzhidao 显示 空格
2显示
空格woyebuzhidao显示 空格
3显示
空格woyebuzhidao 显示 空格
4显示
空格 woyebuzhidao显示 空格
'''