zoukankan      html  css  js  c++  java
  • 字符串

     字符串

    字符串不可更改

    1,字符串格式化

    >>> name='lily'
    >>> age=20
    >>> print('my name is '+ name + " , I'm " + str(age) + " years old")    #字符串拼接,不建议
    my name is lily , I'm 20 years old
    
    >>> print("my name is %s, I'm %s years old" %(name,age))    #字符串格式化 ,推荐
    my name is lily, I'm 20 years old
    
    format 格式化字符串
    >>> print('my name is {} ,and age is {}'.format('lily',22)) my name is lily ,and age is 22 >>> print('my name is {0} , and age is {1}'.format('lily',22)) my name is lily , and age is 22 #位置参数 >>> print('my name is {name}, and age is {age}'.format(age=22,name='lily')) #关键字参数 my name is lily, and age is 22 >>> dic={"name":"lily","age":18} >>> print("name is {name},age is {age}".format(**dic)) name is lily,age is 18 :[填充字符][对齐方式 <^>][宽度] >>> a='A' >>> b='B' >>> c='C' >>> print("{0:<5} {1:^5} {2:>5}".format(a,b,c)) A #左对齐 #居中 #右对齐 B C >>> print("{:*<5} {:*^5} {:*>5}".format(a,b,c)) A**** **B** ****C

    2,常用的字符串功能

    可通过 dir(obj) 查看方法

    索引      obj[0]  obj[-1]
    切片      obj[1:4]  obj[::-1] 倒序
    长度      len(obj)
    移除空白   obj.lstrip() 去头空白    obj.strip() 两头  obj.rstrip() 去尾部空白
    分割     obj.split()
    大小写 obj.title()首字母大写 obj.upper() 大写 obj.lower() 小写

    join() 和split()方法

    join()方法是针对一个字符串而调用的,并且传入一个列表值

    >>> ','.join('hello world')
    'h,e,l,l,o, ,w,o,r,l,d'
    
    
    >>> ' '.join(['my','name','is','lily'])
    'my name is lily'

     split()方法做的事情正好相反:它针对一个字符串调用,返回一个字符串列表。

    >>> 'hi python hello world'.split()
    ['hi', 'python', 'hello', 'world']
    >>> 
    >>> 'mynameislilymyageis22myaimispython'.split('my')
    ['', 'nameislily', 'ageis22', 'aimis

    str

    def capitalize(self): #首字母转换成大写
    >>> 'hello world'.capitalize()
           'Hello world'
    
    def casefold(self): # 全部转换成小写
    >>> 'HELLO world'.casefold()
             'hello world'
    
    def center(self, width, fillchar=None): # 居中
    >>> 'hello world'.center(20,'-')
             '----hello world-----'
    
    def count(self, sub, start=None, end=None): # 计数
    >>> s='hello world!'
    >>> s.count('l')
    >>> s.count('l',1,3)
    
    def encode(self, encoding='utf-8', errors='strict'): #编码 把str变成二进制
     
    编码(encode):string-->bytes
    解码(decode):bytes-->string 
    >>> 'hello'.encode()
    b'hello'
    >>> 
    >>> b'hello'.decode()
    'hello'
    
    def endswith(self, suffix, start=None, end=None): #以什么结尾,startswith 以什么开头
    
    >>> 'hello'.endswith('o')
            True
    >>> 'hello world'.endswith('w',1,7) #指定起始位置
            True
    
    def expandtabs(self, tabsize=8): #字符串中的 tab ('	')转为空格
    >>> s
             'hello	world'
    >>> s.expandtabs()
             'hello   world'
    >>> s.expandtabs(20)
             'hello               world'
    
    def find(self, sub, start=None, end=None): #找到时返回索引,找不到时返回-1.区别于index
    >>> 'hello'.find('e')   
    >>> 'hello'.find('x')
            -1
    
    def format(self, *args, **kwargs): # 格式化字符串
    >>> 'my name is {1} age is {0}'.format(22,'lily')
             'my name is lily age is 22'
    >>> 'my name is {name}'.format(name='lily')
             'my name is lily'
    
    def format_map(self, mapping): # real signature unknown; restored from __doc__
            """
            S.format_map(mapping) -> str
            
            Return a formatted version of S, using substitutions from mapping.
            The substitutions are identified by braces ('{' and '}').
    
    
    def index(self, sub, start=None, end=None): # 找到时返回索引,找不到时报错
    >>> 'hello'.index('e')
    >>> 'hello'.index('y')
             raceback (most recent call last):
             File "<stdin>", line 1, in <module>
             ValueError: substring not found
    
    def isalnum(self): # 都是字母和数字组成
    def isalpha(self):  # 都是由字母组成
    def isdigit(self):    # 都是由数字组成
    def isdecimal(self): #是否只包含十进制字符
    
    def islower(self):    #是否由小写字母组成
    def isnumeric(self): # 是否只由数字组成,只适用于unicode对象
    def isprintable(self): #是否都是可打印字符
    def isspace(self): #是否只由空格组成
    def isidentifier(self): # real signature unknown; restored from __doc__
    
    def istitle(self): # 所有单词拼写首字母为大写,且其他字母为小写。
     >>> s='Hello World'
    >>> s.istitle()
            True
    
    def isupper(self): #所有单词大写
    >>> s='HI123'
    >>> s.isupper()
            True
    def join(self, iterable): # 用指定的字符连接序列中的元素生成一个新的字符串
    >>> l=['a','b','c','d']
    >>> '-'.join(l)
            'a-b-c-d'
    
    def ljust(self, width, fillchar=None): #居左 
    >>> s= 'helloworld'
    >>> s.ljust(20,'*')
            'helloworld**********'
    
    
    
    def lstrip(self, chars=None): # 去除开头的空格
    
    def maketrans(self, *args, **kwargs): # real signature unknown
            
    
    def partition(self, sep): #按照指定分割符将字符串分割
    >>> 'hello'.partition('l')
            ('he', 'l', 'lo')
    
    def split(self, sep=None, maxsplit=-1): # 通过指定分隔符对字符串切片
    >>> 'abacadae'.split('a')
    ['', 'b', 'c', 'd', 'e']
    >>> 'a:b:c'.split(':')
    ['a', 'b', 'c']

     >>> 'a:b:c'.split(':',1)
      ['a', 'b:c']

    
    
    def replace(self, old, new, count=None): # old替换成new,次数(默认全部替换)
    >>> 'hello'.replace('l','x')
            'hexxo'
    >>> 'hello'.replace('l','x',1)
            'hexlo'
    
    def splitlines(self, keepends=None): # real signature unknown; restored from __doc__
    
    def strip(self, chars=None): #去掉前后空格
            """
            S.strip([chars]) -> str
            
            Return a copy of the string S with leading and trailing
            whitespace removed.
            If chars is given and not None, remove characters in chars instead.
            """
            return ""
    
    def swapcase(self): # 大小写转换
    >>> 'helloWORLD'.swapcase()
    'HELLOworld'
    
    def title(self): # 将首字母转换成大写 其他转成小写
    >>> 'HELLO WORLD'.title()
             'Hello World'
    
    def lower(self): # 全部转换成小写
    
    def upper(self): # 全部转换成大写
    >>> 'Hello World'.upper()
             'HELLO WORLD'
    
    def translate(self, table): #根据 table 的规则(可以由 str.maketrans('a', 'b') 定制)转换字符串中的字符
    >>> s
    'hello world'
    >>> s.translate(s.maketrans('l','x'))
    'hexxo worxd'
    
    def zfill(self, width): # 返回指定长度的字符串,原字符串右对齐,前面填充0
  • 相关阅读:
    JDBC
    Android--RelativeLayout
    Android--开发过程中使用到的长度单位
    java--进步学习IO
    java--从控制台读入一些数据
    java--IO
    C语言数据结构-创建链表的四种方法
    标准I/O库函数的缺陷
    Java四种引用包括强引用,软引用,弱引用,虚引用
    算法导论答案(1-11)
  • 原文地址:https://www.cnblogs.com/xiaobaozi-95/p/8717578.html
Copyright © 2011-2022 走看看