美文网首页Python精选
python-day-4 字符串

python-day-4 字符串

作者: Sakura_flower | 来源:发表于2018-09-28 20:45 被阅读25次

    一、复习

    1、字符串(str)

    通过双引号或者单引号引起来的内容就是字符串

    2、Unicode编码

    3、转义字符

    \n --> 换行

    \' --->'

    \t---> 制表符

    \\ ---> \

    \" --->"

    二、字符串中的元素

    1、阻止转义(在字符串的最前面可以添加r/R来阻止字符串中的转义字符转义)

    2、python中可以把字符串看成是一个序列(容器),容器中内容是字符。

    每一个字符可以称为字符串中的元素。字符串是一个不可变的序列,有序(不可变指的是字符串中的每个字符,以及每个字符的位置不可变)

    3、获取字符串中的单个字符

    语法: 字符串[下标] ---> 根据下标获取字符串中的字符

    说明:a.字符串:可以是字符串的变量,也可以是字符串值

            b.[]:固定写法

            c.下标:0~字符串长度-1; -1~-长度

    注意:下标是整数;下标不能越界

    python中的每个字符串中字符都会对应一个下标,下标是根据字符在字符串中的位置,从前往后依次增加的(第一个)

    str3='python'

    p-->0  y-->1  t-->2  h-->3 ....

    m-->-1  o-->-2  h-->-3 ....

    print(str3[0])  # p

    print(str3[-6])  # p

    index=2

    print(str3[index])

    print(str3[6//2])


    注意:一个空格算一个字符,一个转义字符算一个字符,一个制表符也是算一个字符

    4、获取字符串中的部分字符(切片)

    A、语法:字符串[起始下标:结束下标] ---> 获取字符串中从起始下标开始,到结束下标前的所有的字符

    注意:起始下标对应的字符要在结束下标对应的字符的前面,否则取不到值

    str5 = '同九年,汝何秀!'

    print(str5[1:5])     九年,汝

    print(str5[5:-1])    何秀

    B、语法:字符串[起始下标:结束下标:步长] --> 从起始下标开始获取,每步长获取一个,获取到结束下标前为止

    步长为正:从前往后取(起始下标对应的字符要在结束下标对应的字符的前面,否则取不到值)

    步长为负:从后往前去(起始下标对应的字符要在结束下标对应的字符的后面,否则取不到值)

    str5 = '海贼王 、一拳超人、一人之下、进击的巨人'

    print(str5[1:10:2])        贼、拳人一

    print(str5[10:0:-1])       一、人超拳..贼

    C、切片时下标可以省略,省略不同的下标有不同的意义

    省略起始下标:字符串[:结束下标] --->从开头开始取(注意:这儿开头可能是第一个字符也可能是最后一个字符)

    str6 = '阁下何不同风起,扶摇直上九万里'

    print(str6[:4])

    print(str6[:4:-1])

    省略结束下标:字符[起始下标:] ---> 从开始下标取,取完为止

    两个下标都省:字符[:] ---> 全部取完

    注意:切片的时候下标可越界

    print(str6[0:100])       阁下何不同风起,扶摇直上九万里

    print(str6[-100:3])     阁下何

    三、字符串运算符

    python中的字符串支持+、*和比较运算符

    1.字符串的+号运算符

    字符串1 + 字符串2 --->  将字符串1和字符串2拼接在一起产生一个新的字符串

    注意:+ 两边要么都是数字,要么都是字符串,不能一样一个

    str1 = '玉树临风美少年'

    str2 = '揽镜自顾夜不眠'

    print(str1+str2)

    new_str = str1 + ',' + str2 + '!'

    print(new_str)

    print(str1+','+str2)

    2.*

    字符串1 * n ----> 字符串

    n必须是整数

    str3 = '家有千金,行止由心' 

    print(str3*3)            #家有千金,行止由心家有千金,行止由心家有千金,行止由心

    先算乘再算加

    str4 = str1 + str3*2

    print(str4)

    3.比较运算符

    print('abc' == 'abc')  判断两个字符串的值是否相等

    print('abc' != 'ab')

    比较大小:比较两个字符串中从前往后每个字符的编码值的大小,比较到两个字符不相同为止

    print('abcdef' > 'bc')

    判断一个字符是否是数字字符,判断一个字符是否是字母字符

    print('==========')

    char = 'H'

    print('0'<=char<='9')

    print('a'<=char<='z' or "A"<=char<='Z') 

    4.in和not in

    # 字符串1 in 字符串2 ---> 判断字符串1是否在字符串2中或者字符串2中是否包含字符串1,结果为bool值

    print('ab' in 'aaabc')                  True

    print('ab' in 'acb')                       False

    print('ab' not in 'aaabc')             False

    print('ab' not in 'acb')                 True

    5.len()函数

    len是python内置函数,功能是用来获取序列的长度(容器中元素的个数)

    len(序列)

    字符串的长度就是字符串中字符的个数

    print(len('hello'))        5

    str5 = '窗前明月光\n疑是地上霜!'

    print(len(str5))             12

    四、格式字符串

    字符串的内部,通过格式站位符来表示字符串中变化的部分,然后在后面用值来填充变化的部分

    语法;带有占位符的字符串 % (给占位符赋值的值)

    注意:前面有多少个占位符,后面()中就必须有多少值。并且值的个数和值的类型要和前面的占位符一一对应

    %s ---> 字符串

    %d ---> 整数

    %f ---> 小数

    %.nf ---> 保留小数点后n位小数(五舍六入)

    name = '李四'

    age = 20

    money = 10.567

    message= '姓名:%s 年龄:%d 薪资:%.2f' %  (name,age,money)

    print(message)

    print('%d:%c' % (97,97))

    五、字符串的内置函数

    如果第一个字符不是字母,将不会转换

    1.capitalize():将字符串的第一个字符转换为大写,返回一个新的字符串

    str1 = 'love'

    new_str = str1.capitalize()

    print(new_str)              Love

    2.字符串对齐

    a.center(width,fillchar)

    b.ljust(width,fillchar)

    c.rjust(width,fillchar)

    width ---> 长度,新的字符串的总长度      fillchar ---> 剩下部分填充的字符。 字符就是长度是1的字符串

    str2 = 'xxx'

    new_str = str2.center(7,'0')

    print(new_str)              00xxx00

    new_str = str2.ljust(7,'0')

    print(new_str)              xxx0000

    new_str = str2.rjust(7,'0')

    print(new_str)               0000xxx

    3.字符串1.count(字符串2)---> 统计字符串1中字符串2的个数

    print('abcdabcdaaa'.count('ab'))                   2

    print('hello world'.count('l'))                           3

    4.字符串1.endswith(字符串2) ---> 判断字符串1是否以字符串2结尾

    字符串1.startswith(字符串2) ---> 判断字符串1是否以字符串2开头

    str1 = 'when i was'

    print(str1.endswith('was')

    5.字符串1.find(字符串2) --->在字符串1中查找字符串2,返回第一个的开始下标。如果没有就返回-1

    str1 ='when i was young , i have a dream'

    print(str1.find('was'))

    print(str1.find('wasaa')

    6.isnumeric()

    print('1234'.isnumeric())               T

    print('一二五七九'.isnumeric())                 T

    7.isTitle()

    标题化:每个单词首字母大写,其他字母小写

    8.字符串1.join(字符串2)  ---> 将字符串1插入到字符串2中每个字符中间,产生一个新的字符串

    print('aa'.join('xyz'))                  xaayaaz

    六、作业

    1、个性化消息: 将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,如“Hello Eric, would you like to learn some Python today?”。

    name = 'eric'

    print('hello ' + name +','+ 'would you like to learn some Python today?')

    2、调整名字的大小写: 将一个人名存储到一个变量中,再以小写、大写和首字母大写的方式显示这个人名。

    name= 'lucy'

    new_name=name.upper()

    print(new_name)      # 小写转大写

    new_name=name.lower()

    print(new_name)      # 大写转小写

    new_name=name.capitalize()

    print(new_name)       #首字母大写

    3、名言: 找一句你钦佩的名人说的名言,将这个名人的姓名和他的名言打印出来。输出应类似于下面这样(包括引号):Albert Einstein once said, “A person who never made a mistake never tried anything new.”

    celebrity='韩愈'

    str='“事业无穷年”'

    print(celebrity+'曾说过,'+str)

    4、名言2: 重复练习2-5,但将名人的姓名存储在变量famous_person 中,再创建要显示的消息,并将其存储在变量message 中,然后打印这条消息。

    celebrity='韩愈'

    str='“事业无穷年”'

    message=celebrity+'曾说过,'+str

    print(message)

    5、剔除人名中的空白: 存储一个人名,并在其开头和末尾都包含一些空白字符。务必至少使用字符组合"\t" 和"\n" 各一次。 打印这个人名,以显示其开头和末尾的空白。然后,分别使用剔除函数lstrip() 、rstrip() 和strip() 对人名进行处理,并将结果打印出来。

    name='小王'

    name1='小\n王'

    name2='小\t王'

    print(name1)

    print(name2)

    name3 = name.center(6, '0')

    print(name3)                输出结果为:00小王00

    name3 = nameljust(6, '0')

    print(name3)                输出结果为:小王0000

    name3 = namerjust(6, '0')

    print(name3)                输出结果为:0000小王

    相关文章

      网友评论

        本文标题:python-day-4 字符串

        本文链接:https://www.haomeiwen.com/subject/qusloftx.html