欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python3字符串學(xué)習(xí)教程

 更新時(shí)間:2015年08月20日 15:13:19   作者:一線涯  
這篇文章主要介紹了Python3字符串學(xué)習(xí)教程,是Python入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下

字符串類型是python里面最常見的類型,是不可變類型,支持單引號(hào)、雙引號(hào)、三引號(hào),三引號(hào)是一對(duì)連續(xù)的單引號(hào)或者雙引號(hào),允許一個(gè)字符串跨多行。
字符串連接:前面提到的+操作符可用于字符串連接,還可以直接把幾個(gè)字符串連在一起寫,另外調(diào)用join()方法也可以連接字符串。
只適用于字符串連接的操作符:前面提到了一些序列類型共用的操作符,除此之外,字符串還有只屬于自己的操作符,包括格式控制操作符%、字符串模板string.Template、原始字符串操作符r/R、Unicode字符串操作符u/U。

下面列舉一些與字符串類型有關(guān)的模塊。
string:字符串操作相關(guān)函數(shù)和工具,比如Template類。
re:正則表達(dá)式,強(qiáng)大的字符串模式匹配模塊。
struct:字符串和二進(jìn)制之間的切換。
c/StringIO:字符串緩沖對(duì)象,操作方法類似于file對(duì)象。
base64:Base16,32,64數(shù)據(jù)編解碼。
codecs:解碼器注冊(cè)和基類。
crypt:進(jìn)行單方面加密。
difflib:找出序列間的不同。
hashlib:多種不同安全哈系算法和信息摘要算法的API,python2.5廢除。
hma:HMAC信息鑒權(quán)算法的python實(shí)現(xiàn)。
md5:RSA的MD5信息摘要鑒權(quán)。
rotor:提供多平臺(tái)的加解密服務(wù)。
sha:NIAT的安全哈系算法SHA。
stringprep:提供用于IP協(xié)議的Unicode字符串。
textwrap:文本打包和填充。
unicodedata:Unicode數(shù)據(jù)庫(kù)。

Python 3 的源碼的默認(rèn)編碼方式為 UTF-8
在Python 3,所有的字符串都是使用Unicode編碼的字符序列。
utf-8 是一種將字符編碼成字節(jié)序列的方式。字節(jié)即字節(jié),并非字符。字符在計(jì)算機(jī)內(nèi)只是一種抽象。字符串則是一種抽象的序列。在這里我們只討論字符串,不討論字節(jié)。

在Python 中,字符串可以用單引號(hào)括起來,也可以用雙引號(hào),甚至是三引號(hào)。
但如果字符串中含有單引號(hào),你應(yīng)該用雙引號(hào)來括,或者用轉(zhuǎn)義符加單引號(hào)括起來。含有雙引號(hào)的同理。
三引號(hào)的字符串可以換行!

>>> 'Let's go!' 
SyntaxError: invalid syntax 
>>> "Let's go!" 
"Let's go!" 
>>> 'Let\'s go!' 
"Let's go!" 
>>> '''''begin 
and 
next 
end''' 
'begin\nand\nnext\nend' 

字符串是不可修改的,這點(diǎn)很重要!你可以把它想象為字符組成的元組。

>>> s = "HelloWorld" 
>>> s[0] = 'h' 
Traceback (most recent call last): 
 File "<pyshell#123>", line 1, in <module> 
  s[0] = 'h' 
TypeError: 'str' object does not support item assignment 

如果你想修改它,可以先轉(zhuǎn)換成列表,修改完成后再轉(zhuǎn)為字符串。

>>> s 
'HelloWorld' 
>>> L = list(s) 
>>> L 
['H', 'e', 'l', 'l', 'o', 'W', 'o', 'r', 'l', 'd'] 
>>> L[0] = 'h' 
>>> ''.join(L) #這是什么?別著急,下面我們會(huì)談到 
'helloWorld' 

字符串可以進(jìn)行直接拼接,但如果是兩個(gè)變量代表的字符串,你還是用 + 號(hào)吧

>>> s = "Hello""World" 
>>> s 
'HelloWorld' 
>>> s1 = "Hello" 
>>> s2 = "World" 
>>> s1s2 
Traceback (most recent call last): 
 File "<pyshell#138>", line 1, in <module> 
  s1s2 
NameError: name 's1s2' is not defined 
>>> s1+s2 
'HelloWorld' 

字符串操作和方法:
len(s)  返回字符串長(zhǎng)度
x in s 查詢 x 是否在 s 中

>>> s = "HelloWorld" 
>>> len(s) 
10 
>>> "ll" in s 
True 

s.find( x )  在字符串 s 中找子串 x ,找到則返回最左端的索引,找不到則返回-1

>>> s 
'HelloWorld' 
>>> s.find("l") 
2 
>>> s.find('w') 
-1 

s.splitlines() 將多行字符串分割成多個(gè)單行字符串組成的列表,換行符被吸收

>>> s = '''''begin 
...then.. 
...next.. 
end...''' 
>>> s.splitlines() 
['begin', '...then..', '...next..', 'end...'] 

s.split( x ) 以 x 作為分隔符將 s 分割成一個(gè)字符串列表,如果不提供x,則程序會(huì)自動(dòng)將所有空格和換行作為分隔符分割

>>> s = "here#there" 
>>> s.split('#') # #作為分隔符 
['here', 'there'] 
>>> s = '''''begin 
.then.. and 
.next. 
end''' 
>>> s.split() #默認(rèn)情況將所有換行和空格都分割 
['begin', '.then..', 'and', '.next.', 'end'] 

s.lower()   返回s 的小寫形式的字符串
s.upper() 返回 s 的大寫形式的字符串

>>> s = 'HelloWorld' 
>>> s.lower() 
'helloworld' 
>>> s.upper() 
'HELLOWORLD' 

s.join( seq )  split 的逆方法,將序列 seq 用 s 連接起來,必須是字符串序列

>>> L = ['1','33','42'] 
>>> '+'.join(L) #用+來連接 
'1+33+42' 
>>> L = list(s) #拆開s 
>>> L 
['H', 'e', 'l', 'l', 'o', 'W', 'o', 'r', 'l', 'd'] 
>>> ''.join(L) #粘合了。。。 
'HelloWorld' 

s.replace( x, y)  將 s 中所有匹配 x 的項(xiàng)用 y 代替,如果找不到,那就直接返回 s 咯

>>> s 
'HelloWorld' 
>>> s.replace("World","Cheng") 
'HelloCheng' 
>>> s.replace("world","Cheng") #知道為什么吧... 
'HelloWorld' 

s.strip( x ) 如果不提供 x,那么返回去除了首尾兩側(cè)空格的字符串,如果提供了字符串 x,那么將去除s首尾所有在 x 中的字符并返回

>>> s = "  Hi,I'm Alice!  " 
>>> s.strip() 
"Hi,I'm Alice!" 
>>> s.strip("! ") #這是兩個(gè)字符哦 
"Hi,I'm Alice" #少了一個(gè)感嘆號(hào)哦! 

再次注意:以上方法都沒有改變?cè)址?,字符串是不可改變的?/p>

以下簡(jiǎn)單看看:
s.starstwith( x )  測(cè)試 s 是否以 x 開頭
s.endswith( x )  測(cè)試 s 是否以 x 結(jié)尾
s.isalnum()  測(cè)試 s 是否全是字母和數(shù)字,并至少有一個(gè)字符
s.isalpha()   測(cè)試 s 是否全是字母,并至少有一個(gè)字符
s.isdigit()  測(cè)試 s 是否全是數(shù)字,并至少有一個(gè)字符
s.isspace()  測(cè)試 s 是否全是空白字符,并至少有一個(gè)字符
s.islower() 測(cè)試 s 中的字母是否全是小寫
s.isupper() 測(cè)試 s 中的字母是否便是大寫
s.istitle() 測(cè)試 s 是否是首字母大寫的

讓我們重點(diǎn)關(guān)注一個(gè)強(qiáng)大的格式化方法 format ,看下面代碼

>>> name = 'Jonh' 
>>> call = '13560300xxx' 
>>> "{0}'s telephone number is {1}".format(name,call) # (1) 
"Jonh's telephone number is 13560300xxx" 
>>> addr = "A103" 
>>> "{0}'s telephone number is {1} and his address is {2}".format(name,call,addr) #(2) 
"Jonh's telephone number is 13560300xxx and his address is A103" 

(1)句中,字符串中 {0} 被 format 的第一個(gè)參數(shù)代替,{1} 被第二個(gè)參數(shù)代替。兩個(gè)參數(shù)不夠?事實(shí)上,你可以給予它任意多個(gè)參數(shù),然后用相同個(gè)數(shù)的替換字段進(jìn)行替換。什么是替換字段?{0},{1}就叫做替換字段。我們?cè)诘冢?)句中使用了3個(gè)替換字段,{0}對(duì)應(yīng)name, {1}對(duì)應(yīng)call,{2}對(duì)應(yīng)addr。再多的參數(shù)也類似于剛才的做法。
那么,僅僅是這樣?當(dāng)然不是!讓我們繼續(xù)看

>>> L = [2,3,5,7] 
>>> print("x is {0[0]}, y is {0[2]}".format(L)) 
x is 2, y is 5 

{0[0]} 表示L[0],{0[2]} 表示L[2],它們叫做復(fù)合字段名,你可以:
(1)使用列表作為參數(shù),并且通過下標(biāo)索引來訪問其元素(跟上一例類似)
(2)使用字典作為參數(shù),并且通過鍵來訪問其值

>>> d 
{'b': 2, 'a': 1} 
>>> print("x is {0[a]}, y is {0[b]}".format(d)) 
x is 1, y is 2 
>>> d = {2:3.5,7:4.5} 
>>> print("x is {0[2]}, y is {0[7]}".format(d)) 
x is 3.5, y is 4.5 

d 為字典,a 、b為鍵,{0[a]} 對(duì)應(yīng)到了值2(注意:是a,b,不是'a', 'b')
(3)使用模塊作為參數(shù),并且通過名字來訪問其變量及函數(shù)

>>> print("{0.random}".format(random)) 
<built-in method random of Random object at 0x022D61F8> 

(4)使用類的實(shí)例作為參數(shù),并且通過名字來訪問其方法和屬性

>>> class A: 
  pass 
 
>>> x = A() 
>>> print("The class is {0.__class__}".format(x)) 
The class is <class '__main__.A'> 

(5)以上方法的任意組合

替換字段除了整數(shù),你還可以使用參數(shù)名字

>>> print("{name}'s telephone number is {call}".format(name = "Jonh",call = 69993)) 
Jonh's telephone number is 69993 

在替換域中,你還可以使用格式說明符。冒號(hào) : 標(biāo)示格式說明符的開始。

>>> pi = 3.141592653 
>>> print("The pi is {0:10.3f}".format(pi)) # 0:10.3f 表示輸出寬度為10,保留三位小數(shù),浮點(diǎn)數(shù) 
The pi is   3.142 

相關(guān)文章

  • python中關(guān)于for循環(huán)的碎碎念

    python中關(guān)于for循環(huán)的碎碎念

    這篇文章主要介紹了python中關(guān)于for循環(huán)使用過程中的碎碎念,需要的朋友可以參考下
    2017-06-06
  • PyQt5實(shí)現(xiàn)QLineEdit添加clicked信號(hào)的方法

    PyQt5實(shí)現(xiàn)QLineEdit添加clicked信號(hào)的方法

    今天小編就為大家分享一篇PyQt5實(shí)現(xiàn)QLineEdit添加clicked信號(hào)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • 利用python?OpenCV去除視頻水印

    利用python?OpenCV去除視頻水印

    這篇文章主要介紹了利用python?OpenCV去除視頻水印,下面我們將利用視頻的某一幀將圖片的一些污點(diǎn)去掉,代碼先從視頻中導(dǎo)出一幀圖片,然后統(tǒng)計(jì)需要?jiǎng)h除按鈕的坐標(biāo)位置,然后再對(duì)視頻中的每一幀圖像做處理的函數(shù),下面操作過程需要的小伙伴可以參考一下
    2022-02-02
  • Pytorch之保存讀取模型實(shí)例

    Pytorch之保存讀取模型實(shí)例

    今天小編就為大家分享一篇Pytorch之保存讀取模型實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 基于Python實(shí)現(xiàn)人像雪景小程序

    基于Python實(shí)現(xiàn)人像雪景小程序

    這篇文章主要介紹了通過Python實(shí)現(xiàn)的人像雪景小程序,小程序還會(huì)自動(dòng)生成每一幀雪花飄落的圖片,跟GIF動(dòng)態(tài)雪花人像圖,還不用自己錄制視頻看效果。感興趣的可以跟隨小編一起學(xué)習(xí)一下
    2021-12-12
  • 詳解Python如何通過文件后綴整理文件夾

    詳解Python如何通過文件后綴整理文件夾

    這篇文章主要為大家詳細(xì)介紹了Python如何通過文件后綴實(shí)現(xiàn)整理文件夾功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • 詳解Python中深淺拷貝的使用及注意事項(xiàng)

    詳解Python中深淺拷貝的使用及注意事項(xiàng)

    Python中的深淺拷貝是經(jīng)常被使用的概念,對(duì)于初學(xué)者來說可能會(huì)比較難以理解,本文將詳細(xì)闡述Python深淺拷貝的概念、使用場(chǎng)景、注意事項(xiàng)以及如何實(shí)現(xiàn)深淺拷貝
    2023-04-04
  • win8.1安裝Python 2.7版環(huán)境圖文詳解

    win8.1安裝Python 2.7版環(huán)境圖文詳解

    在本篇內(nèi)容里小編給大家分享了關(guān)于win8.1安裝Python 2.7版環(huán)境的詳細(xì)步驟和方法,有興趣的朋友們跟著學(xué)習(xí)下。
    2019-07-07
  • 教女朋友學(xué)Python(一)運(yùn)行環(huán)境搭建

    教女朋友學(xué)Python(一)運(yùn)行環(huán)境搭建

    這篇文章主要介紹了教女朋友學(xué)Python(一)運(yùn)行環(huán)境搭建,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-11-11
  • 在交互式環(huán)境中執(zhí)行Python程序過程詳解

    在交互式環(huán)境中執(zhí)行Python程序過程詳解

    這篇文章主要介紹了在交互式環(huán)境中執(zhí)行Python程序過程詳解,運(yùn)行Python腳本程序的方式有多種,目前主要的方式有:交互式環(huán)境運(yùn)行、命令行窗口運(yùn)行、開發(fā)工具上運(yùn)行等,其中在不同的操作平臺(tái)上還互不相同,需要的朋友可以參考下
    2019-07-07

最新評(píng)論