測試環(huán)境:Centos7+Python3.5
1.字符串拼接
正常情況用 “+” 號即可拼接字符串。但如果不用“+”號相鄰的兩個或多個字符串也會自動連接。
# 相鄰的兩個或多個字符串會自動連接
>>> 'Py' 'thon'
'Python'
2.字符串轉義
參考: http://www.runoob.com/python/python-strings.html
對于Python而言,正常情況是默認轉義的,如下:
# 默認轉義
>>> print('C:\some\name')
C:\some
ame
如果不想轉義的話,可以在字符串前面添加 r(real)
>>> print(r'C:\some\name')
C:\some\name
3.字符串重復
>>> 'ha' * 3
'hahaha'
4.字符串切片
字符串也可看作一個字符列表,所以可以像列表那樣支持切片和索引,在此不再贅述。
5.字符串的分割
>>> a = 'aa bb'
>>> a.split(' ') # 空格分割
['aa', 'bb']
6.字符串的替換
>>> a.replace('aa', 'cc') # 空格替換
'cc bb'
注:當輸入的字符串沒有規(guī)律時,用split和replace有點危險,因為有可能其它字符也會被分割替換
7.字符串格式化
字符串格式化有多種方式, 有 % 或者format函數(shù),現(xiàn)在Python越來越推崇用 format 函數(shù)。
主要參考這篇文章:https://www.cnblogs.com/wilber2013/p/4641616.html
%c:轉換成字符(ASCII 碼值,或者長度為一的字符串)
%r:優(yōu)先用repr()函數(shù)進行字符串轉換
%s:優(yōu)先用str()函數(shù)進行字符串轉換
%d / %i / %u:轉成有符號十進制數(shù)。%u 本來是無符號十進制數(shù),但是在文檔中 %u 和 %d 是等同的。
%o:轉成無符號八進制數(shù)
%x / %X:轉成無符號十六進制數(shù)(x / X 代表轉換后的十六進制字符的大小寫)
%e / %E:轉成科學計數(shù)法(e / E控制輸出e / E)
%f / %F:轉成浮點數(shù)(小數(shù)部分自然截斷)
%%:輸出% (格式化字符串里面包括百分號,那么必須使用%%)
>>> string = 'Hello\tWorld\n'
>>> print("%r" %string)
'Hello\tWorld\n'
>>> print("%s" %string)
Hello World
>>> i = 18
>>> f = 40.0234
>>> s = 'John'
>>> print('the age of %s is %d, his salary are %.2f' % (s, i, f))
the age of John is 18, his salary are 40.02
>>> i = 1222222222
>>> print('%e' %i)
1.222222e+09
格式化操作符輔助符
m.n: m 是顯示的最小總寬度,n 是小數(shù)點后的位數(shù)(如果可用的話)
%.2f: m未指定,所以無窮; n指定2,所以保留兩位。
格式化內建函數(shù)
Format 內建函數(shù)有兩種表現(xiàn)形式。第一種是通過數(shù)字來表示是第幾個參數(shù);第二種是通過關鍵字參數(shù)來表示,如下:
# 數(shù)字表示
>>> "hello {0}".format("John")
'hello John'
amp;ensp;
# 關鍵字參數(shù)
>>> "hello {name}, your uid is {uid}".format(name="John", uid=123)
'hello John, your uid is 123'
8.補充
- str()和repr()兩個內建函數(shù)之間的差異:
str()得到的字符串是面向用戶的,具有較好的可讀性;
repr()得到的字符串是面向機器的
>>> string = "Hello\tWill\n"
>>> print("%s" % string)
>>> print("%r" % string)
Hello Will
amp;ensp;
'Hello\tWill\n'