005 Python語法之字符串

字符串(可用*)

字符串的定義

str1 = "abc"

訪問字符串中的值

str1 = "abcde"
print(str1[0])      -->  a
print(str1[0:3])    -->  abc
print(str1[:3])     -->  abc
print(str1[0:-1])   -->  abcd
print(str1[2:])     -->  cde
print(str1[:])      -->  abcde
print(str1[0:-1:2]) -->  ac

索引介紹

  1. str1[0]:這種[]中只有一個數(shù)字的是訪問單個字符,索引從0-len(str1)-1
  2. str1[0:3]:這種擁有兩個索引,中間用冒號連接的是訪問索引從0-2的元素abc,索引包左不包右
  3. str1[:3]:這個相當(dāng)于str1[0:3],左邊缺省代表從0開始
  4. str1[0:-1]:這個相當(dāng)于從0訪問到倒數(shù)第二個元素,-1代表最大的索引,但是因為包左不包右,所以最后一個元素獲取不到
  5. str1[2:]:缺省右邊相當(dāng)于從2開始訪問到最后一個元素
  6. str1[:]:兩邊都缺省相當(dāng)于str1字符串本身,它們的id一致
  7. str1[0:-1:2]:這個和4一樣,但是最后那個2代表的是步進(jìn)的意思,就是每兩個字符取一個字符

索引注意點

  1. [a:b]:包括a不包括b
  2. 換行也是一個字符
  3. 最后一個元素索引為-1,然后一直往前-2 -3...

遍歷字符串

str1 = "fdsgkfjgk"
for i in str1:
    print(i)

轉(zhuǎn)義字符

轉(zhuǎn)義字符 描述
\(在行尾時) 續(xù)行符
\\ 反斜杠符號
\' 單引號
\" 雙引號
\a 響鈴
\b 退格(Backspace)
\e 轉(zhuǎn)義
\000
\n 換行
\v 縱向制表符
\t 橫向制表符
\r 回車
\f 換頁
\oyy 八進(jìn)制數(shù),yy代表的字符,例如:\o12代表換行
\xyy 十六進(jìn)制數(shù),yy代表的字符,例如:\x0a代表換行
\other 其它的字符以普通格式輸出

python用反斜杠(\)轉(zhuǎn)義字符

轉(zhuǎn)義字符 描述
\(在行尾時) 續(xù)行符
\\ 反斜杠符號
\' 單引號
\" 雙引號
\a 響鈴
\b 退格(Backspace)
\e 轉(zhuǎn)義
\000
\n 換行
\v 縱向制表符
\t 橫向制表符
\r 回車
\f 換頁
\oyy 八進(jìn)制數(shù),yy代表的字符,例如:\o12代表換行
\xyy 十六進(jìn)制數(shù),yy代表的字符,例如:\x0a代表換行
\other 其它的字符以普通格式輸出

字符串運算符

變量a值為字符串 "Hello",b變量值為 "Python":

操作符 描述 實例
+ 字符串連接 a + b 輸出結(jié)果: HelloPython
* 重復(fù)輸出字符串 a*2 輸出結(jié)果:HelloHello
[] 通過索引獲取字符串中字符 a[1] 輸出結(jié)果 e
[:] 截取字符串中的一部分 a[1:4] 輸出結(jié)果 ell
in 成員運算符 如果字符串中包含給定的字符返回 True H in a 輸出結(jié)果 1
not in 成員運算符:如果字符串中不包含給定的字符返回 True M not in a 輸出結(jié)果 1
r/R 使所有的字符串都是直接按照字面的意思來使用,在字符串的第一個引號前加上字母r或R print r'\n' prints \n 和 print R'\n' prints \n

格式化

符號 描述
%c 格式化字符及其ASCII碼
%s 格式化字符串
%d 格式化整數(shù)
%u 格式化無符號整型
%o 格式化無符號八進(jìn)制數(shù)
%x 格式化無符號十六進(jìn)制數(shù)
%X 格式化無符號十六進(jìn)制數(shù)(大寫)
%f 格式化浮點數(shù)字,可指定小數(shù)點后的精度
%e 用科學(xué)計數(shù)法格式化浮點數(shù)
%E 作用同%e,用科學(xué)計數(shù)法格式化浮點數(shù)
%g %f和%e的簡寫
%G %f 和 %E 的簡寫
%p 用十六進(jìn)制數(shù)格式化變量的地址

格式化的使用

print("%s" % "123") --> "123"
print("%d" % 123)   --> 123
print("%5.2f"% 12.345)  --> 12.35
print("%05.2f"% 12.34)  --> 012.34

格式化的解析

  1. %s 是格式化字符串,就是一段字符串中缺省一段字符串可以用%s代替,% 后面的可以用一個字符串的變量或者常量替換
  2. %d 是格式化整數(shù),%后面的用一個整數(shù)替換
  3. %5.2f 是格式化浮點數(shù), 5 代表的是占用5個字符的空間, 2 代表的是保留小數(shù)點后面兩位小數(shù)
  4. 如果在%5.2f前面填入0,,%05.2f是表示用0填充,原本左邊默認(rèn)用空格填充
  5. %%代表一個%,相當(dāng)于轉(zhuǎn)義************

format()函數(shù)

format(12.3456, "<10.2f")
格式化,10代表占位10個字符,.2代表小數(shù)點后保留兩位小數(shù),<表示左對齊,>表示右對齊,f表示浮點數(shù)

format("dsfafd", "<10s")
<表示左對齊,>表示右對齊,s表示字符串,10表示占位10個字符長度

info = """--info--
name:{_name}
age:{_age}
""".format(_name="luo",_age=123)
print(info)

info2 = """--info--
name:{0}
age:{1}
""".format("luo",123)
print(info2)

Unicode-ACSII-UTF-8編碼

  1. ASCII格式,沒有中文可以編譯
  2. UTF-8包括ASCII
  3. UTF-8格式編譯中文
  4. UTF-8格式占用空間較大
  5. Python3默認(rèn)字符串是UTF-8 (utf-8, unicode-8, unicode-16)
  6. 在Python2中表示unicode編碼需要加上u前綴u"hello world"

r/R轉(zhuǎn)義

  1. r除了雙引號之外的都可以處理
  2. print(r"") -->輸出 字符串原樣

字符串常用函數(shù)

方法 描述
capitalize() 將字符串的第一個字符轉(zhuǎn)換為大寫
center(width, fillchar) 返回一個指定的寬度 width 居中的字符串,fillchar 為填充的字符,默認(rèn)為空格
count(str, beg= 0,end=len(string)) 返回 str 在 string 里面出現(xiàn)的次數(shù),如果 beg 或者 end 指定則返回指定范圍內(nèi) str 出現(xiàn)的次數(shù)
bytes.decode(encoding="utf-8", errors="strict") Python3 中沒有 decode 方法,但我們可以使用 bytes 對象的 decode() 方法來解碼給定的 bytes 對象,這個 bytes 對象可以由 str.encode() 來編碼返回
encode(encoding='UTF-8',errors='strict') 以 encoding 指定的編碼格式編碼字符串,如果出錯默認(rèn)報一個ValueError 的異常,除非 errors 指定的是'ignore'或者'replace'
endswith(suffix, beg=0, end=len(string)) 檢查字符串是否以 obj 結(jié)束,如果beg 或者 end 指定則檢查指定的范圍內(nèi)是否以 obj 結(jié)束,如果是,返回 True,否則返回 False.
expandtabs(tabsize=8) 把字符串 string 中的 tab 符號轉(zhuǎn)為空格,tab 符號默認(rèn)的空格數(shù)是 8 。
find(str, beg=0 end=len(string)) 檢測 str 是否包含在字符串中 中,如果 beg 和 end 指定范圍,則檢查是否包含在指定范圍內(nèi),如果是返回開始的索引值,否則返回-1
index(str, beg=0, end=len(string)) 跟find()方法一樣,只不過如果str不在字符串中會報一個異常
isalnum() 如果字符串至少有一個字符并且所有字符都是字母或數(shù)字則返 回 True,否則返回 False
isalpha() 如果字符串至少有一個字符并且所有字符都是字母則返回 True, 否則返回 False
isdigit() 如果字符串只包含數(shù)字則返回 True 否則返回 False
islower() 如果字符串中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是小寫,則返回 True,否則返回 False
isnumeric() 如果字符串中只包含數(shù)字字符,則返回 True,否則返回 False
isspace() 如果字符串中只包含空格,則返回 True,否則返回 False.
istitle() 如果字符串是標(biāo)題化的(見 title())則返回 True,否則返回 False
isupper() 如果字符串中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是大寫,則返回 True,否則返回 False
isidentifier() 判斷是否是合法的標(biāo)識符
join(seq) 以指定字符串作為分隔符,將 seq 中所有的元素(的字符串表示)合并為一個新的字符串
len(string) 返回字符串長度
ljust(width[, fillchar]) 返回一個原字符串左對齊,并使用 fillchar 填充至長度 width 的新字符串,fillchar 默認(rèn)為空格
lower() 轉(zhuǎn)換字符串中所有大寫字符為小寫
lstrip() 截掉字符串左邊的空格
maketrans() 創(chuàng)建字符映射的轉(zhuǎn)換表,對于接受兩個參數(shù)的最簡單的調(diào)用方式,第一個參數(shù)是字符串,表示需要轉(zhuǎn)換的字符,第二個參數(shù)也是字符串表示轉(zhuǎn)換的目標(biāo)
max(str) 返回字符串 str 中最大的字母
min(str) 返回字符串 str 中最小的字母
replace(old, new [, max]) 把 將字符串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次
rfind(str, beg=0,end=len(string)) 類似于 find()函數(shù),不過是從右邊開始查找
rindex( str, beg=0, end=len(string)) 類似于 index(),不過是從右邊開始
rjust(width,[, fillchar]) 返回一個原字符串右對齊,并使用fillchar(默認(rèn)空格)填充至長度 width 的新字符串
rstrip() 刪除字符串字符串末尾的空格
split(str="", num=string.count(str)) num=string.count(str)) 以 str 為分隔符截取字符串,如果 num 有指定值,則僅截取 num 個子字符串
splitlines([keepends]) 按照行('\r', '\r\n', \n')分隔,返回一個包含各行作為元素的列表,如果參數(shù) keepends 為 False,不包含換行符,如果為 True,則保留換行符
startswith(str, beg=0,end=len(string)) 檢查字符串是否是以 obj 開頭,是則返回 True,否則返回 False。如果beg 和 end 指定值,則在指定范圍內(nèi)檢查
strip([chars]) 在字符串上執(zhí)行 lstrip()和 rstrip()
swapcase() 將字符串中大寫轉(zhuǎn)換為小寫,小寫轉(zhuǎn)換為大寫
title() 返回"標(biāo)題化"的字符串,就是說所有單詞都是以大寫開始,其余字母均為小寫(見 istitle())
translate(table, deletechars="") 根據(jù) str 給出的表(包含 256 個字符)轉(zhuǎn)換 string 的字符, 要過濾掉的字符放到 deletechars 參數(shù)中
upper() 轉(zhuǎn)換字符串中的小寫字母為大寫
zfill (width) 返回長度為 width 的字符串,原字符串右對齊,前面填充0
isdecimal() 檢查字符串是否只包含十進(jìn)制字符,如果是返回 true,否則返回 false

字符串的一些方法介紹

ord(ch)

ch="a"
print(ord(ch))

-----打印----
97

ord函數(shù)介紹

  1. 參數(shù)1:單個字符,多個字符會報錯
  2. 返回值是一個十進(jìn)制的ASCII碼

count函數(shù)

mystr.count("python")

count函數(shù)介紹

  1. 判斷python字符串在mystr字符串中出現(xiàn)的次數(shù)
  2. 參數(shù)1:要查找的字符串
  3. 參數(shù)2:開始查找的索引
  4. 參數(shù)3:結(jié)束查找的索引
  5. 返回值:出現(xiàn)的次數(shù)

encode函數(shù)編碼

"你好".encode(encoding="utf-8",errors="strict") -->  bytes

encode函數(shù)介紹

  1. 將字符串進(jìn)行編碼
  2. 參數(shù)1:編碼方式
  3. 參數(shù)2:糾錯級別
  4. 返回值:bytes二進(jìn)制數(shù)據(jù)

decode函數(shù)編碼(這個方法是bytes的方法)

b"\xce\xd2\xb5".decode(encoding="utf-8",errors="strict") -->  str

decode函數(shù)介紹

  1. 將字符串進(jìn)行解碼
  2. 參數(shù)1:解碼方式
  3. 參數(shù)2:糾錯級別
  4. 返回值:字符串

splitlines函數(shù)

lineList = str1.splitlines()

splitlines函數(shù)

  1. 按照\n進(jìn)行分割
  2. 返回值是一個列表

字符串模板(可以用來寫詩)

from string import Template # 字符串模板包
myStr = Template("hi,$name 你是 $baby")
print(myStr.substitute(name="Luo", baby="lovely baby"))

字符串模板介紹

  1. 這個是一個字符串模板對象,可以生成一系列的字符串
  2. $name:代表一個參數(shù)name
  3. 返回值是一個字符串模板
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 本節(jié)要介紹的是Python里面常用的幾種數(shù)據(jù)結(jié)構(gòu)。通常情況下,聲明一個變量只保存一個值是遠(yuǎn)遠(yuǎn)不夠的,我們需要將一組...
    小黑y99閱讀 65,585評論 0 9
  • 第5章 引用類型(返回首頁) 本章內(nèi)容 使用對象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類型 使用基本類型...
    大學(xué)一百閱讀 3,674評論 0 4
  • 我喜歡這個世界 或者因為我的唯心主義 誰能看見 我的窗外 下雨了
    桔樹上閱讀 227評論 0 0
  • 1月24日,像往常一樣真真起來給我做早餐,我點了最喜歡吃的米粉,可是真真給做過了,她用內(nèi)疚的眼神看著我,半可憐半撒...
    壹土拾具閱讀 213評論 0 1
  • 話說當(dāng)日潘金蓮被武二郎砍去頭顱,剖心挖肺以祭武大郎的在天之靈后,路過的地府鬼差旋即鎖了潘金蓮的鬼魂,羈往陰曹地府,...
    蟲鳴吹晚風(fēng)閱讀 2,782評論 1 5

友情鏈接更多精彩內(nèi)容