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,babcf)

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显示 空格

'''