亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python入門篇之字符串

系統 1952 0

所有標準的序列操作對字符串都適用,但字符串是不可變的

字符串常量:

單引號:‘spa"m'

雙引號:"spa'm"

三引號:'''...spam...''',"""...spam..."""

轉義字符:"s\tp\na\om"

Raw字符串:r"C:\new\test.spm"

Unicode字符串:u'eggs\u0020spam

單雙引號是一樣的
單雙引號可以互換,字符常量表達式可以用兩個單引號或兩個雙引號來表示--兩種形式同樣有效返回相同類型的對象:

復制代碼 代碼如下:

>>> 'zxcvbn',"zxcvbn"
('zxcvbn', 'zxcvbn')
>>> #不適用轉義字符就可以實現在一個字符串中包含其余種類 的引號
>>> 'knight"s',"knight's"
('knight"s', "knight's")

可以自動在任意的表達式中合并相鄰的字符串常量,盡管也可以使用+操作符實現:

復制代碼 代碼如下:

>>> title="sdfsd"'dfg'"fgfd"
>>> title
'sdfsddfgfgfd'

字符串的格式化使用字符%來實現:

在%的左側放置一個字符串,右側放置希望格式化的值,可以使用一個值,也可以使用多個值的元組或字典

復制代碼 代碼如下:

>>> format="Hello. %s. %s enough for ya?"
>>> values=('world','Hot')
>>> print format % values
Hello. world. Hot enough for ya?

如果需要轉換的元組作為轉換表達式的一部分存在,那么必須將它用圓括號括起來,以免出錯

長字符串、原始字符串
1、長字符串

如果需要寫一個非常長的字符串,需要跨多行,則可以使用三個引號代替普通引號

復制代碼 代碼如下:

>>> print '''this is
a
very long
string'''
this is
a
very long
string

如果一行之中最后一個字符是反斜線,那么換行符本身就“轉義”了,也就是被忽略了

復制代碼 代碼如下:

>>> print "hello.\
world!"
hello.world!
>>> #這個用法也適用表達式和語句
>>> 1+2+\
????? 4+5
12
>>> print \
????? 'hello.world'
hello.world

2、原始字符串

原始字符串以r開頭,可以在原始字符串中放入任何字符,最后輸出的字符串包含了轉義所用的反斜線,但是不能在字符串結尾輸入反斜線:

復制代碼 代碼如下:

>>> print \
????? 'hello.world'
hello.world
>>> print r'Let\'s go!'
Let\'s go!
>>> print r'this is illegal\'
SyntaxError: EOL while scanning string literal

索引與分片

字符串的字符是通過索引來提取的,將獲得在特定位置的一個字符的字符串。

Python偏移量是從0開始的,并比字符串的長度小1,還支持類似在字符串中使用負偏移這樣的方法從序列中獲取元素,負偏移認作是從結束處反向計數

當使用一對冒號分隔的偏移索引字符串這樣的序列對象時,將獲取從下邊界直到但不包括上邊界的所有元素

索引(s[i])獲取特定偏移的元素:

第一個元素的偏移為0

負偏移索引意味著從最后或右邊反向進行計數

s[0]獲取第一個元素

s[-2]獲取了倒數第二個元素

分片(s[i:j])提取對應的部分作為一個序列:

上邊界并不包含在內

分片的邊界默認為0和序列的長度,如果沒有給出的話

s[1:3]獲取從偏移為1的元素,直到但不包括偏移為3的元素

s[1:]獲取了從偏移為1直到末尾之間的元素

s[:3]獲取了從偏移為0直到但是不包括偏移為3之間的元素

s[:-1]獲取了從偏移為0直到但是不包括最后一個元素之間的元素

s[:]獲取了從偏移0到末尾之間的元素

復制代碼 代碼如下:

>>> s='spam'
>>> s[0],s[-2]
('s', 'a')
>>> s[1:3],s[1:],s[:-1]
('pa', 'pam', 'spa')
>>> s[0],s[-2]
('s', 'a')

擴展分片:第三個限制值

分片表達式增加了一個可選的第三個索引,用作步進X[I:J:K]表示:索引X對象中的元素,從偏移為I直到偏移為J-1,每隔K元素索引一次

復制代碼 代碼如下:

>>> s='abcdefghijklmnop'
>>> s[1:10:2]
'bdfhj'
>>> s[::2]
'acegikmo'
>>> s='hello'
>>> s[::-1]
'olleh'
>>> s[4:1:-1]
'oll'

字符串轉換工具

復制代碼 代碼如下:

>>> '42'+1
Traceback (most recent call last):
? File " ", line 1, in
??? '42'+1
TypeError: cannot concatenate 'str' and 'int' objects
>>> int('42'),str(42)
(42, '42')
>>> repr(42),'42'
('42', '42')
>>> s='42'
>>> i=1
>>> s+i
Traceback (most recent call last):
? File " ", line 1, in
??? s+i
TypeError: cannot concatenate 'str' and 'int' objects
>>> int(s)+i
43
>>> s+str(i)
'421'
>>> #類似也可以把浮點數轉換成字符串或把字符串轉換成浮點數
>>> str(3.1415),float("1.3")
('3.1415', 1.3)
>>> text='1.23E-10'
>>> float(text)
1.23e-10

字符串代碼轉換

單個字符也可以通過將其傳給內置的ord函數轉換為其對應的ASCII碼,chr函數則執行相反的操作:

復制代碼 代碼如下:

>>> ord('s')
115
>>> chr(115)
's'

字符串方法

字符串比列表的方法還要豐富很多,因為字符串從string模塊中“繼承”了很多方法,本篇文章只介紹一些特別有用的字符串方法

?1、find

find方法可以在一個較長的字符串中查找一個子字符串,它返回子串所在位置的最左端索引,如果沒有找到則返回-1

復制代碼 代碼如下:

>>> 'with a moo-moo here, and a moo-moo there'.find('moo')
7
>>> title="Monty Python's Flying Cirus"
>>> title.find('Monty')
0
>>> title.find('Python')
6
>>> title.find('Zirquss')
-1

這個方法可以接受可選的起始點和結束點參數:

復制代碼 代碼如下:

>>> subject='$$$ Get rich now!!! $$$'
>>> subject.find('$$$')
0
>>> subject.find('$$$',1)
20
>>> subject.find('!!!')
16
>>> subject.find('!!!',0,16)
-1

2、join

join方法是非常重要的字符串方法,它是split方法的逆方法,用來在隊列中添加元素:

復制代碼 代碼如下:

>>> seq=[1,2,3,4,5]
>>> sep='+'
>>> sep.join(seq)

Traceback (most recent call last):
? File " ", line 1, in
??? sep.join(seq)
TypeError: sequence item 0: expected string, int found
>>> seq=['1','2','3','4','5']
>>> sep.join(seq)
'1+2+3+4+5'
>>> dirs='','usr','bin','env'

>>> '/'.join(dirs)
'/usr/bin/env'
>>> print 'C:'+'\\'.join(dirs)
C:\usr\bin\env

3、lower

lower方法返回字符串的小寫字母版

復制代碼 代碼如下:

>>> 'HDWUD HDJHS LKJDS'.lower()
'hdwud hdjhs lkjds'

4、replace

replace方法返回某字符串的所有匹配項均被替換后得到字符串

復制代碼 代碼如下:

>>> 'This is a test'.replace('is','eez')
'Theez eez a test'

5、split

它是join的逆方法,用來將字符串分割成序列

復制代碼 代碼如下:

>>> '1+2+3+4+5'.split('+')
['1', '2', '3', '4', '5']
>>> 'C:\usr\bin\env'.split('/')
['C:\\usr\x08in\\env']
>>> 'Using the default'.split()
['Using', 'the', 'default']

注意:如果不提供任何分隔符,程序會把所有的空格作為分隔符

6、strip

strip方法返回去除兩側(不包含內部)空格的字符串:

復制代碼 代碼如下:

>>> '???? internal whitespace is kept???? '.strip()
'internal whitespace is kept'

也可指定需要去除的字符,將它們列為參數即可:

復制代碼 代碼如下:

>>> '*** SPAM * for * everyone!!! ***'.strip(' *!')
'SPAM * for * everyone'

注意:只會去除兩側的字符

7、translate

translate方法和replace方法一樣,可以替換字符串中的某些部分,但是和前者不同的是,translate方法只處理單個字符


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久久精品2021免费观看 | 亚洲在线久久 | 四虎影院永久网址 | 亚洲激情网址 | 欧美日韩国产58香蕉在线视频 | 99精品视频在线观看re | 欧美一级毛片高清免费观看 | 波多野结衣一区在线 | 久99久热只有精品国产99 | 亚洲成人性视频 | 成人小视频在线 | 五月狠狠亚洲小说专区 | 久久久久女人精品毛片九一 | 无人码一区二区三区视频 | 国产手机在线国内精品 | 在线看片亚洲 | 97在线看片免费福利视频 | 草久在线 | 国产精品免费久久 | 天天草比 | 岛国片欧美一级毛片 | 狠狠大日本亚洲香蕉亚洲 | 成年性午夜免费视频网站不卡 | 久久久久久毛片免费播放 | 欧美性猛交xxxx免费看久久 | 国产青草视频免费观看97 | 牛牛a级毛片在线播放 | 久久综合免费视频 | 中文字幕在线看视频一区二区三区 | 成人亚州 | 夜夜艹天天干 | 黄色在线网站视频 | 日韩欧美在线免费观看 | 中文在线播放 | 99视频精品全部国产盗摄视频 | 欧美成人免费 | 久久精品国产欧美 | 97在线视频免费播放 | 美女很黄很黄免费的 | 国产香蕉一区二区精品视频 | 日本在线亚洲 |