在Python中字串的表達方式有四種
- 一對單引號
- 一對雙引號
- 一對三個單引號
- 一對三個雙引號
a = 'abc'
b= "abc"
c = '''abc'''
d = """abc"""
print(type(a)) # <class 'str'>
print(type(b)) # <class 'str'>
print(type(c)) # <class 'str'>
print(type(d)) # <class 'str'>
單雙引號混合使用
a = "LiMing say 'nice to meet you'"
同樣也可以通過轉義的方式不用在裡面寫雙引號
a = "LiMing say \"nice to meet you\""
print(a)
總結就是需要外面用了雙引號,裡面需要引用的語句可以用單引號括起來,反之亦然。
通常情況根據個人喜好,基本都是使用單引號或者雙引號。有些特殊情況,比如需要表示多行時,可以選擇三個單(雙)引號,並且無序用\
進行轉移,可直接使用單引號和雙引號。
a = '''
My Name is 阿亮,
Let's say 'Hello'
'''
print(a)
字串的下標和切換
下標:字串是一個個字元拼接而成,下標可以理解為每個字元的編號,從0開始依次類推。
作用:通過下標去操作字串中的元素
# H的下標為0, e的下標為1 ..依次類推
a = 'HelloWorld'
# 獲取字串a中下標為4的元素
print(a[4]) # o 下標為4的元素為o
修改字串中的元素是不是可以直接賦值呢? 例如:
a = 'HelloWorld'
a[4] = 'k'
print(a)
上面的程式碼執行之後發現報錯。
TypeError: 'str' object does not support item assignment
原因是因為: 字串一旦建立之後,裡面的元素是不可以修改的。
所以字串是無法直接進行修改的。
字串運算
字串運算中用到了+
、*
、>
、<
、!=
、=
等邏輯運算子。
字串的相加操作,也可以理解為拼接操作。例如:
a = 'Hello' + ' World'
print(a) # Hello World
# 也可以寫成
a = 'Hello' ' World'
print(a) # Hello World
字串的乘法操作, 可以理解為克隆操作,字串只能與整數(n)想乘,代表克隆n個字串。
a = 'a'
print(a * 2) # aa
b = '-'
print(b * 10) # ----------
切片
字串的切片也稱為字串擷取。 所有操作都是通過字串的下標進行操作的。
用法:字串[開始索引(start):結束索引(end):步長(step)(預設1)]
步長(step):每隔(step-1)個取一個元素,當step為負數時,代表從右向左取元素,
a = 'abcdefghijklmn'
# 從下標1開始 到4結束 進行切片 (包括1,不包括4,即左開又閉)
print(a[1:4]) # bcd
print(a[1:8]) # bcdefgh
print(a[1:8:2])# 步長為2, 結果:bdfh
# 當補償為負數時,代表逆向擷取。 初始從座標8開始,每隔一個元素取一個值,到下標為1時結束
print(a[8:1:-2]) # igec
字串的常用操作
這裡以程式碼+註釋的方式,展示幾個常用的字串操作。
a = ' Hello World '
# 獲取字串的長度
print(len(a)) # 13
# 刪除字串兩邊的空格
print(a.strip()) # Hello World
# 刪除左邊的空格
print(a.lstrip()) # Hello World (只刪除左邊的空格)
# 刪除字串右邊的空格
print(a.rstrip()) # Hello World
# 通過指定連線符 連結字串
lst = ['LiMing', 'Tom']
print('***'.join(lst)) # LiMing***Tom
# 首字母大寫
m = 'hello world'
print(m.capitalize()) # Hello world
# 返回標題化字串,即每個單詞首字母大寫
print(m.title()) # Hello World
# 列印輸出字元,將字串放在中間,
# center(width, fillchar) width: 字串的總長度, fillchar:填充字元
print(a.center(20, '*')) # *** Hello World ****
# 是否以xxx開頭
n = 'Hello'
print(n.startswith('H')) # True
# 是否以xxx結尾
print(n.endswith('o')) # True
# 字串是全純英文字元
print(a.isalpha()) # False , 因為字串a中 ' Hello World ' 有空格,因此返回False
print('HelloWorld'.isalpha()) #True
# 判斷字串中是否全部為數字或者英文
print('Hello2World'.isalnum()) # True
print('123'.isalnum()) # True
print('abc&11'.isalnum()) # False
# 判斷是否為整數
print('123'.isdigit()) # True
print('1.23'.isdigit()) # False
# 判斷字元是否全為小寫
print('abc'.islower()) # True
# 判斷字元是否全為大寫
print('Abc'.isupper()) # False
print('ABC'.isupper()) # True
# 字串小寫轉大寫
print('abc'.upper()) # ABC
# 字串大寫轉小寫
print('ABC'.lower()) # abc
# 字串的替換
b = 'aabbcc'.replace('a', 'm')
print(b) # mmbbcc
# 1 代表替換的個數
b = 'aabbcc'.replace('a', 'm', 1)
print(b) # mabbcc
# split 字串切割,預設空格切割
print('aa bb cc'.split()) # ['aa', 'bb', 'cc']
print('ab,cd,ef'.split(',')) # ['ab', 'cd', 'ef']
# 字串換行分割
a = """
My Name is 'Python極客專欄',
歡迎關注
"""
print(a.splitlines()) # ['', " My Name is 'Python極客專欄',", ' 歡迎關注', ' ']
字串的查詢
字串查詢常用的方法用index
、find
兩者功能相似,區別在於find查詢不到元素時返回 -1
, 不會影響程式執行,而index則會丟擲異常。
a = 'abcdef'
# 查詢到元素返回對應的下標
print(a.find('c')) # 2
print(a.find('h')) # -1
print(a.index('c')) # 2
print(a.index('h')) # 丟擲異常,ValueError: substring not found
rfind: 類似於find()函式,不過是從右邊開始查詢;返回字串最後一次出現的位置,如果沒有匹配項則返回-1 。rindex 同理
a = 'acmncd'
# 從右邊開始計算,返回第一個匹配到的下標
print(a.rfind('c')) # 4
print(a.rindex('c')) # 4
字串的格式化
name = 'Python極客專欄'
# %s 用於輸出字串
print('我的公眾號是: %s' % name)
age = 18
# %d 用於輸出十進位制數字
print('我的年齡是:%d' % age)
money = 1.23
# %f 浮點數,預設顯示小數點後6位
print('我身上有:%f 元' % money )
# 指定小數點後的位數
print('我身上有:%.2f 元' % money )
format操作
除了使用 % 進行格式化,也可以使用format
print('{} {}'.format('Hello', 'World')) # Hello World
print('{0} {1}'.format('Hello', 'World')) # Hello World
print('公眾號{name}, 分享{code} 技術'.format(name='Python極客專欄', code='Python')) # 公眾號Python極客專欄, 分享Python 技術
print('{1}, {0}, {1}'.format('A', 'B')) #B, A, B
print('今年是 {}年.'.format(2020)) # 今年是 2020年.