日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

零基础学Python(第十一章 字符串处理)

發布時間:2024/8/26 python 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 零基础学Python(第十一章 字符串处理) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本套學習內容共計【22】個章節,每個章節都會有對應的從0-1的學習過程詳細講解,希望可以給更多的人提供幫助。

開發環境:【Win10】

開發工具:【Visual Studio 2019】

本章內容為:字符串處理。

字符串是 Python 中最常用的數據類型。我們可以使用引號('或")來創建字符串。

創建字符串很簡單,只要為變量分配一個值即可。例如:

var1 = 'Hello World!' var2 = "你好 世界"

1、Python 字符串連接,使用【,】或【+】

var1 = 'Hello World!' print("輸出 :- ", var1[:6] + '世界!')#前6個字符

2、Python 轉義字符(可參照ASCII表)

在需要在字符中使用特殊字符時,python 用反斜杠?\?轉義字符。如下表:

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

3、Python字符串運算符

下表實例變量 a 值為字符串 "Hello",b 變量值為 "Python":

操作符描述實例
+字符串連接

>>>a + b 'HelloPython'

*重復輸出字符串

>>>a * 2 'HelloHello'

[]通過索引獲取字符串中字符

>>>a[1] 'e'

[ : ]截取字符串中的一部分

>>>a[1:4] 'ell'

in成員運算符 - 如果字符串中包含給定的字符返回 True

>>>"H" in a True

not in成員運算符 - 如果字符串中不包含給定的字符返回 True

>>>"M" not in a True

r/R原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思來使用,沒有轉義特殊或不能打印的字符。 原始字符串除在字符串的第一個引號前加上字母"r"(可以大小寫)以外,與普通字符串有著幾乎完全相同的語法。

>>>print r'\n' \n >>> print R'\n' \n

演示代碼:

a = "Hello" b = "Python"print("a + b 輸出結果:", a + b ) print("a * 2 輸出結果:", a * 2 ) print("a[1] 輸出結果:", a[1] ) print("a[1:4] 輸出結果:", a[1:4] )if( "H" in a) :print("H 在變量 a 中") else :print("H 不在變量 a 中") if( "M" not in a) :print("M 不在變量 a 中") else :print("M 在變量 a 中")print(r'\n') print(R'\n')

4、Python 字符串格式化(用的比較多)

print("%s擁有一個%s,是一個%s的%s"% ("你","世界","寬廣美好","樂園"))

python 字符串格式化符號:

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

格式化操作符輔助指令:

符號功能
*定義寬度或者小數點精度
-用做左對齊
+在正數前面顯示加號( + )
<sp>在正數前面顯示空格
#在八進制數前面顯示零('0'),在十六進制前面顯示'0x'或者'0X'(取決于用的是'x'還是'X')
0顯示的數字前面填充'0'而不是默認的空格
%'%%'輸出一個單一的'%'
(var)映射變量(字典參數)
m.n.m 是顯示的最小總寬度,n 是小數點后的位數(如果可用的話)

5、format?拼接

拼接方法有很多:常用的方法【"{0}{1}~~~".format("","",~~~)】

#直接鏈接 print('hello''python')# format 拼接 str.format(args,**kwargs) # 例(1) {} 充當占位符 str_word = 'hello, word! {} {}'.format('張三', '李四') print(str_word) # 例(2) {[index]} 按索引位置填充 .format([0]=value1, [1]= value1},) str_word_index0 = 'hell0, word!{0},{1}'.format('張三', '李四') str_word_index1 = 'hell0, word!{1},{0}'.format('張三', '李四') print(str_word_index0) print(str_word_index1) # 例(3) {[keyword]} str_word_keyword = 'hell0, word!{a},'.format(b='張三', a='李四') print(str_word_keyword) # 例(4) {[keyword,indec]} keyword 放在最后 str_word1 = 'hell0, word!{1}{a}{0},'.format('index0', 'index1', b='張三', a='李四') print(str_word1) # 例(5) format 參數類型不限,當為元祖,列表,集合,字典時輸出 str_word2 = 'hell0, word!'.format(b=['eee', 'd']) print(str_word2) # 例(6) 作為函數使用 str_word3 = 'hello, word! {} {}'.format word = str_word3('張三', '李四') print(word)

樣例效果:

6、Unicode 字符串

Python 中定義一個 Unicode 字符串和定義一個普通字符串一樣簡單:

str=u'Hello\u0020World !' print(str)

注:print(json.encode('utf-8').decode('unicode_escape'))編碼格式化

7、Python的字符串內建函數(本章節會分開為一個系列講述)

由于內容較多,在后面用到的時候會具體講述:

方法描述

string.capitalize()

把字符串的第一個字符大寫

string.center(width)

返回一個原字符串居中,并使用空格填充至長度 width 的新字符串

string.count(str, beg=0, end=len(string))

返回 str 在 string 里面出現的次數,如果 beg 或者 end 指定則返回指定范圍內 str 出現的次數

string.decode(encoding='UTF-8', errors='strict')

以 encoding 指定的編碼格式解碼 string,如果出錯默認報一個 ValueError 的 異 常 , 除非 errors 指 定 的 是 'ignore' 或 者'replace'

string.encode(encoding='UTF-8', errors='strict')

以 encoding 指定的編碼格式編碼 string,如果出錯默認報一個ValueError 的異常,除非 errors 指定的是'ignore'或者'replace'

string.endswith(obj, beg=0, end=len(string))

檢查字符串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的范圍內是否以 obj 結束,如果是,返回 True,否則返回 False.

string.expandtabs(tabsize=8)

把字符串 string 中的 tab 符號轉為空格,tab 符號默認的空格數是 8。

string.find(str, beg=0, end=len(string))

檢測 str 是否包含在 string 中,如果 beg 和 end 指定范圍,則檢查是否包含在指定范圍內,如果是返回開始的索引值,否則返回-1

string.format()

格式化字符串

string.index(str, beg=0, end=len(string))

跟find()方法一樣,只不過如果str不在 string中會報一個異常.

string.isalnum()

如果 string 至少有一個字符并且所有字符都是字母或數字則返

回 True,否則返回 False

string.isalpha()

如果 string 至少有一個字符并且所有字符都是字母則返回 True,

否則返回 False

string.isdecimal()

如果 string 只包含十進制數字則返回 True 否則返回 False.

string.isdigit()

如果 string 只包含數字則返回 True 否則返回 False.

string.islower()

如果 string 中包含至少一個區分大小寫的字符,并且所有這些(區分大小寫的)字符都是小寫,則返回 True,否則返回 False

string.isnumeric()

如果 string 中只包含數字字符,則返回 True,否則返回 False

string.isspace()

如果 string 中只包含空格,則返回 True,否則返回 False.

string.istitle()

如果 string 是標題化的(見 title())則返回 True,否則返回 False

string.isupper()

如果 string 中包含至少一個區分大小寫的字符,并且所有這些(區分大小寫的)字符都是大寫,則返回 True,否則返回 False

string.join(seq)

以 string 作為分隔符,將 seq 中所有的元素(的字符串表示)合并為一個新的字符串

string.ljust(width)

返回一個原字符串左對齊,并使用空格填充至長度 width 的新字符串

string.lower()

轉換 string 中所有大寫字符為小寫.

string.lstrip()

截掉 string 左邊的空格

string.maketrans(intab, outtab])

maketrans() 方法用于創建字符映射的轉換表,對于接受兩個參數的最簡單的調用方式,第一個參數是字符串,表示需要轉換的字符,第二個參數也是字符串表示轉換的目標。

max(str)

返回字符串?str?中最大的字母。

min(str)

返回字符串?str?中最小的字母。

string.partition(str)

有點像 find()和 split()的結合體,從 str 出現的第一個位置起,把 字 符 串 string 分 成 一 個 3 元 素 的 元 組 (string_pre_str,str,string_post_str),如果 string 中不包含str 則 string_pre_str == string.

string.replace(str1, str2,? num=string.count(str1))

把 string 中的 str1 替換成 str2,如果 num 指定,則替換不超過 num 次.

string.rfind(str, beg=0,end=len(string) )

類似于 find() 函數,返回字符串最后一次出現的位置,如果沒有匹配項則返回 -1。

string.rindex( str, beg=0,end=len(string))

類似于 index(),不過是從右邊開始.

string.rjust(width)

返回一個原字符串右對齊,并使用空格填充至長度 width 的新字符串

string.rpartition(str)

類似于 partition()函數,不過是從右邊開始查找

string.rstrip()

刪除 string 字符串末尾的空格.

string.split(str="", num=string.count(str))

以 str 為分隔符切片 string,如果 num 有指定值,則僅分隔 num+ 個子字符串

string.splitlines([keepends])

按照行('\r', '\r\n', \n')分隔,返回一個包含各行作為元素的列表,如果參數 keepends 為 False,不包含換行符,如果為 True,則保留換行符。

string.startswith(obj, beg=0,end=len(string))

檢查字符串是否是以 obj 開頭,是則返回 True,否則返回 False。如果beg 和 end 指定值,則在指定范圍內檢查.

string.strip([obj])

在 string 上執行 lstrip()和 rstrip()

string.swapcase()

翻轉 string 中的大小寫

string.title()

返回"標題化"的 string,就是說所有單詞都是以大寫開始,其余字母均為小寫(見 istitle())

string.translate(str, del="")

根據 str 給出的表(包含 256 個字符)轉換 string 的字符,

要過濾掉的字符放到 del 參數中

string.upper()

轉換 string 中的小寫字母為大寫

string.zfill(width)

返回長度為 width 的字符串,原字符串 string 右對齊,前面填充0

8、總結:?

a)、本章節主要是讓大家掌握字符串的各種拼接方式,方便后面做各種各樣的字符串格式化處理。

本課程目錄為:

Python初級

1 、開發工具

2 、中文編碼

3 、基礎語法

4 、變量類型

5 、運算符

6 、條件語句

7 、while循環

8 、for循環

9 、循環控制

10、 循環嵌套

11 、字符串(本章)

12 、列表

13 、元組

14、 字典

15 、日期時間

16、 函數

17 、模塊

18 、文件I/O

19 、File方法

20 、異常處理

21 、文件目錄

22 、內置函數

歡迎【點贊】、【評論】、【關注】、【收藏】、【打賞】,為推廣知識貢獻力量。

總結

以上是生活随笔為你收集整理的零基础学Python(第十一章 字符串处理)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。