python123除以b代码_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,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显示 空格

'''

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值