zoukankan      html  css  js  c++  java
  • 014,字符串:各种奇葩的内置方法

    014,字符串:各种奇葩的内置方法

     字符串的方法及注释
     capitalize()
      
      把字符串的第一个字符改为大写
      
      casefold()
      
      把整个字符串的所有字符改为小写
      
      center(width)
      
      将字符串居中,并使用空格填充至长度width的新字符串
      
      count(sub[,start[,end]])
      
      返回sub在字符串里边出现的次数,start和end参数表示范围,可选。
      
      encode(encoding='utf-8', errors='strict')
      
      以encoding指定的编码格式对字符串进行编码。
      
      endswith(sub[,start[,end]])
      
      检查字符串是否以sub子字符串结束,如果是返回True,否则返回False。start和end参数表示范围,可选。
      
      expandtabs([tabsize=8])
      
      把字符串中的tab符号( )转换为空格,如不指定参数,默认的空格数是tabsize=8。
      
      find(sub[,start[,end]])
      
      检测sub是否包含在字符串中,如果有则返回索引值,否则返回-1,start和end参数表示范围,可选。
      
      index(sub[,start[,end]])
      
      跟find方法一样,不过如果sub不在string中会产生一个异常。
      
      isalnum()
      
      如果字符串至少有一个字符并且所有字符都是字母或数字则返回True,否则返回False。
      
      isalpha()
      
      如果字符串至少有一个字符并且所有字符都是字母则返回True,否则返回False。
      
      isdecimal()
      
      如果字符串只包含十进制数字则返回True,否则返回False。
      
      isdigit()
      
      如果字符串只包含数字则返回True,否则返回False。
      
      islower()
      
      如果字符串中至少包含一个区分大小写的字符,并且这些字符都是小写,则返回True,否则返回False。
      
      isnumeric()
      
      如果字符串中只包含数字字符,则返回True,否则返回False。
      
      isspace()
      
      如果字符串中只包含空格,则返回True,否则返回False。
      
      istitle()
      
      如果字符串是标题化(所有的单词都是以大写开始,其余字母均小写),则返回True,否则返回False。
      
      isupper()
      
      如果字符串中至少包含一个区分大小写的字符,并且这些字符都是大写,则返回True,否则返回False。
      
      join(sub)
      
      以字符串作为分隔符,插入到sub中所有的字符之间。
      >>> str5 = 'Fishc' >>> str5.join('12345')  '1Fishc2Fishc3Fishc4Fishc5'
      ljust(width)
      
      返回一个左对齐的字符串,并使用空格填充至长度为width的新字符串。
      
      lower()
      
      转换字符串中所有大写字符为小写。
      
      lstrip()
      
      去掉字符串左边的所有空格
      
      partition(sub)
      
      找到子字符串sub,把字符串分成一个3元组(pre_sub,sub,fol_sub),如果字符串中不包含sub则返回(‘原字符串’, ’’, ’’)
      
      replace(old,new[,count])
      
      把字符串中的old子字符串替换成new子字符串,如果count指定,则替换不超过count次。>>> str7 = 'i love fishdm and seven' 
      >>> str7.replace('e','E',2)            'i lovE fishdm and sEven'
      rfind(sub[,start[,end]])
      
      类似于find()方法,不过是从右边开始查找。
      
      rindex(sub[,start[,end]])
      
      类似于index()方法,不过是从右边开始。
      
      rjust(width)
      
      返回一个右对齐的字符串,并使用空格填充至长度为width的新字符串。
      
      rpartition(sub)
      
      类似于partition()方法,不过是从右边开始查找。
      
      rstrip()
      
      删除字符串末尾的空格。
      
      split(sep=None,  maxsplit=-1)
      
      不带参数默认是以空格为分隔符切片字符串,如果maxsplit参数有设置,则仅分隔maxsplit个子字符串,返回切片后的子字符串拼接的列表。
      >>> str7.split ()   ['i', 'love', 'fishdm', 'and', 'seven']
      splitlines(([keepends]))
      
      按照‘ ’分隔,返回一个包含各行作为元素的列表,如果keepends参数指定,则返回前keepends行。
      
      startswith(prefix[,start[,end]])
      
      检查字符串是否以prefix开头,是则返回True,否则返回False。start和end参数可以指定范围检查,可选。
      
      strip([chars])
      
      删除字符串前边和后边所有的空格,chars参数可以定制删除的字符,可选。
      
      swapcase()
      
      翻转字符串中的大小写。
      
      title()
      
      返回标题化(所有的单词都是以大写开始,其余字母均小写)的字符串。
      
      translate(table)
      
      根据table的规则(可以由str.maketrans(‘a’,‘b’)定制)转换字符串中的字符。>>> str8 = 'aaasss sssaaa'
      >>> str8.translate(str.maketrans('s','b'))     'aaabbb bbbaaa'
      upper()
      
      转换字符串中的所有小写字符为大写。
      
      zfill(width)
      
      返回长度为width的字符串,原字符串右对齐,前边用0填充。
      

    测试题:

       
    0. 还记得如何定义一个跨越多行的字符串吗(请至少写出两种实现的方法)?
    答: 三引号
    论坛参考答案:
    方法一:
       
    >>> str1 = '''待我长发及腰,将军归来可好?
    此身君子意逍遥,怎料山河萧萧。
    天光乍破遇,暮雪白头老。
    寒剑默听奔雷,长枪独守空壕。
    醉卧沙场君莫笑,一夜吹彻画角。
    江南晚来客,红绳结发梢。'''
       
    方法二:
       
    >>> str2 = '待卿长发及腰,我必凯旋回朝。
    昔日纵马任逍遥,俱是少年英豪。
    东都霞色好,西湖烟波渺。
    执枪血战八方,誓守山河多娇。
    应有得胜归来日,与卿共度良宵。
    盼携手终老,愿与子同袍。'
       
    方法三:
       
    >>> str3 = ('待卿长发及腰,我必凯旋回朝。'
    '昔日纵马任逍遥,俱是少年英豪。'
    '东都霞色好,西湖烟波渺。'
    '执枪血战八方,誓守山河多娇。'
    '应有得胜归来日,与卿共度良宵。'
    '盼携手终老,愿与子同袍。')

    1. 三引号字符串通常我们用于做什么使用?
    答:分行?
    论坛参考答案:
    三引号字符串不赋值的情况下,通常当作跨行注释使用,例如:
    1. '''这是一个三引号字符串用于注释的例子,
    2. 例子虽然只是简简单单的一句话,
    3. 却毫无遮掩地体现了作者用情至深,
    4. 所谓爱至深处情至简!'''
    5. print("I love FishC.com!")

    2. file1 = open('C:windows emp eadme.txt', 'r') 表示以只读方式打开“C:windows emp eadme.txt”这个文本文件,但事实上这个语句会报错,知道为什么吗?你会如何修改?  
    答:语句里的反斜杠会被系统认为断行。修改为:C:\windows\temp\readme.txt 
    论坛参考答案:
    会报错是因为在字符串中,我们约定“ ”和“ ”分别表示“横向制表符(TAB)”和“回车符”(详见:http://bbs.fishc.com/thread-39140-1-1.html),因此并不会按照我们计划的路径去打开文件。
       
    Python 为我们铺好了解决的道路,只需要使用原始字符串操作符(R或r)即可:
    1. >>> file1 = open(r'C:windows emp eadme.txt', 'r')

    3. 有字符串:str1 = '<a href="www.fishc.com/dvd" target="_blank">鱼C资源打包</a>',请问如何提取出子字符串:'www.fishc.com'
    答:str1[16:29] 

    4. 如果使用负数作为索引值进行分片操作,按照第三题的要求你能够正确目测出结果吗? 
    答:
    " target="_bla 
    论坛参考答案:
    1. >>> str1[-45:-32]

    5. 还是第三题那个字符串,请问下边语句会显示什么内容?
    1. >>> str1[20:-36]
     答:'fishc'
    论坛参考答案:
    'fishc',加入了负数索引,问题变得有些复杂,不过自己多尝试几次就可以熟练掌握了。

    6. 据说只有智商高于150的鱼油才能解开这个字符串(还原为有意义的字符串):str1 = 'i2sl54ovvvb4e3bferi32s56h;$c43.sfc67o0cm99' 
    答:
    str1[::3]

    动动手:
      
    0. 请写一个密码安全性检查的脚本代码:check.py  
    # 密码安全性检查代码
    #
    # 低级密码要求:
    #   1. 密码由单纯的数字或字母组成
    #   2. 密码长度小于等于8位
    #
    # 中级密码要求:
    #   1. 密码必须由数字、字母或特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|)任意两种组合
    #   2. 密码长度不能低于8位
    #
    # 高级密码要求:
    #   1. 密码必须由数字、字母及特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|)三种组合
    #   2. 密码只能由字母开头
    #   3. 密码长度不能低于16位
     程序演示:
    图片

    答:摸索了一个多小时。不会。
    论坛参考答案(慢慢消化):
     
    #
    #   1. 
    #   2. 8
    #
    #   1. ~!@#$%^&*()_=-/,.?<>;:[]{}|
    #   2. 8
    #
    #   1. ~!@#$%^&*()_=-/,.?<>;:[]{}|
    #   2. 
    #   3. 16
     
    symbols = r'''`!@#$%^&*()_+-=/*{}[]|'";:/?,.<>'''
    chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
    nums = '0123456789'
     
    passwd = input('')
     
    length = len(passwd)
     
    while (passwd.isspace() or length == 0) :
        passwd = input("")
     
    if length <= 8:
        flag_len = 1
    elif 8 < length < 16:
        flag_len = 2
    else:
        flag_len = 3
     
    flag_con = 0
     
    for each in passwd:
        if each in symbols:
            flag_con += 1
            break
        
    for each in passwd:
        if each in chars:
            flag_con += 1
            break
     
    for each in passwd:
        if each in nums:
            flag_con += 1
            break    
     
    while 1 :
        print("", end='')
        if flag_len == 1 or flag_con == 1 :
            print("")
        elif flag_len == 2 or flag_con == 2 :
            print("")
        else :
            print("")
            print("")
            break
     
        print("
         1. 
         2. 
         3. 16'")
        break
  • 相关阅读:
    [CF1295E] Permutation Separation
    [APIO2010] 特别行动队
    [CF1296F] Berland Beauty
    [CEOI2004] 锯木厂选址
    [CF1334E] Divisor Paths
    Review 2020.11.14
    [CQOI2016] 手机号码
    [LEETCODE600] 不含连续1的非负整数
    [CF55D] Beautiful numbers
    内存取证工具volatility
  • 原文地址:https://www.cnblogs.com/fishdm/p/3573938.html
Copyright © 2011-2022 走看看