美文网首页
2018-08-22 day3 python基础语法(二)字符串

2018-08-22 day3 python基础语法(二)字符串

作者: nothingpy | 来源:发表于2018-08-22 17:34 被阅读0次

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

    相关文章

      网友评论

          本文标题:2018-08-22 day3 python基础语法(二)字符串

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