1、字符串--是不可变的

定义及初始化

In [577]: s = 'hello wolrd'

In [578]: s
Out[578]: 'hello wolrd'

In [579]: s = "hello python"

In [580]: s
Out[580]: 'hello python'

In [581]: s = '''hello'''

In [582]: s
Out[582]: 'hello'

In [583]: s = """hello"""

In [584]: s
Out[584]: 'hello'

In [585]: 

In [585]: s = '''hello python
     ...: i like python'''

In [586]: s
Out[586]: 'hello python\ni like python'


转义

In [587]: s = 'i like \npython'

In [588]: s
Out[588]: 'i like \npython'

In [589]: print(s)
i like 
python

In [590]: s = 'i\'m martin'

In [591]: s
Out[591]: "i'm martin"

In [592]: path = 'C:\\windows\nt\systemew'

In [593]: path
Out[593]: 'C:\\windows\nt\\systemew'

In [594]: print(path)
C:\windows
t\systemew

In [595]: path = 'C:\\windows\\nt\systemew'

In [596]: print(path)
C:\windows\nt\systemew

In [597]: path =r'C:\\windows\nt\systemew'  # 加r前缀代表此字符串是自然字符串, 不会转义

In [598]: print(path)
C:\\windows\nt\systemew


下标操作

In [599]: s
Out[599]: "i'm martin"

In [600]: s[3]
Out[600]: ' '

In [601]: s[0]
Out[601]: 'i'

In [602]: type(s[0])
Out[602]: str

In [603]: 

In [603]: s = 'martin'

In [604]: for i in s:   #字符串是可迭代对象
     ...:     print(i)
     ...:     
m
a
r
t
i
n

In [605]: list(s)
Out[605]: ['m', 'a', 'r', 't', 'i', 'n']


字符串的操作

In [607]: lst = ['i','am','martin']

In [608]: lst
Out[608]: ['i', 'am', 'martin']

In [609]: ' '.join(lst)
Out[609]: 'i am martin'

In [610]: 

In [610]: s = 'i love python'

In [611]: s.split()
Out[611]: ['i', 'love', 'python']

In [612]: '      love python'.split()
Out[612]: ['love', 'python']

In [613]: '      love python'.split(' ')
Out[613]: ['', '', '', '', '', '', 'love', 'python']

In [614]: s.split(maxsplit=1)
Out[614]: ['i', 'love python']

In [615]: s = '''i am martin
     ...: i love python'''

In [616]: s.splitlines()
Out[616]: ['i am martin', 'i love python']

In [617]: 'i am martin'.partition(' ')
Out[617]: ('i', ' ', 'am martin')

In [618]: cfg = 'env = PATH=/usr/bin;$PATH'

In [619]: cfg.partition('=')
Out[619]: ('env ', '=', ' PATH=/usr/bin;$PATH')

In [620]: s = 'test'

In [621]: s.upper()
Out[621]: 'TEST'

In [622]: s.upper().lower()
Out[622]: 'test'

In [623]: s.title()
Out[623]: 'Test'

In [624]: s.center(30)
Out[624]: '             test             '
In [625]: s = 'hahahah   hehe'

In [626]: s.strip()
Out[626]: 'hahahah   hehe'

列表, 元组, 字符串, bytes, bytearray

都是顺序存储, 顺序访问的, 都是可迭代对象, 都可以通过索引访问

In [629]: list(enumerate([1,2,3]))
Out[629]: [(0, 1), (1, 2), (2, 3)]


In [630]: lst = list(range(10))

In [631]: lst
Out[631]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

In [632]: lst[3]
Out[632]: 3

In [633]: lst[3:7]
Out[633]: [3, 4, 5, 6]

In [634]: lst[3:7:2]
Out[634]: [3, 5]

In [635]: lst[3:]
Out[635]: [3, 4, 5, 6, 7, 8, 9]

In [636]: lst[:7]
Out[636]: [0, 1, 2, 3, 4, 5, 6]

In [637]: lst[:]
Out[637]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

In [638]: lst[8:5:-1]
Out[638]: [8, 7, 6]