Python中的字串處理

來源:互聯網
上載者:User

標籤:

 Python逸出字元

在需要在字元中使用特殊字元時,python用反斜線(\)逸出字元。如下表:

逸出字元 描述
\(在行尾時) 續行符
\\ 反斜線符號
\‘ 單引號
\" 雙引號
\a 響鈴
\b 退格(Backspace)
\e 轉義
\000
\n 換行
\v 縱向定位字元
\t 橫向定位字元
\r 斷行符號
\f 換頁
\oyy 八位元yy代表的字元,例如:\o12代表換行
\xyy 十進位數yy代表的字元,例如:\x0a代表換行
\other 其它的字元以普通格式輸出
Python字串運算子

下表執行個體變數a值為字串"Hello",b變數值為"Python":

操作符 描述 執行個體
+ 字串串連 a + b 輸出結果: HelloPython
* 重複輸出字串 a*2 輸出結果:HelloHello
[] 通過索引擷取字串中字元 a[1] 輸出結果 e
[ : ] 截取字串中的一部分 a[1:4] 輸出結果 ell
in 成員運算子 - 如果字串中包含給定的字元返回 True H in a 輸出結果 1
not in 成員運算子 - 如果字串中不包含給定的字元返回 True M not in a 輸出結果 1
r/R 原始字串 - 原始字串:所有的字串都是直接按照字面的意思來使用,沒有轉義特殊或不能列印的字元。 原始字串除在字串的第一個引號前加上字母"r"(可以大小寫)以外,與一般字元串有著幾乎完全相同的文法。 print r‘\n‘ prints \n 和 print R‘\n‘prints \n
% 格式字串 情看一下章節
Python字串格式化

Python 支援格式化字串的輸出 。儘管這樣可能會用到非常複雜的運算式,但最基本的用法是將一個值插入到一個有字串格式符 %s 的字串中。

在 Python 中,字串格式化使用與 C 中 sprintf 函數一樣的文法。

如下執行個體:

#!/usr/bin/pythonprint "My name is %s and weight is %d kg!" % (‘Zara‘, 21) 

以上執行個體輸出結果:

My name is Zara and weight is 21 kg!

python字串格式化符號:

<tbody

    符   號 描述
      %c  格式化字元及其ASCII碼
      %s  格式化字串
      %d  格式化整數
      %u  格式化無符號整型
      %o  格式化無符號八位元
      %x  格式化無符號十六進位數
      %X  格式化無符號十六進位數(大寫)
      %f  格式化浮點數字,可指定小數點後的精度
      %e  用科學計數法格式化浮點數
      %E  作用同%e,用科學計數法格式化浮點數
      %g  根據值的大小決定使用%f活%e
      %G  作用同%g,根據值的大小決定使用%f活%e
      %p  用十六進位數格式化變數的地址

格式化操作符輔助指令:

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

python中三引號可以將複雜的字串進行複製:

python三引號允許一個字串跨多行,字串中可以包含分行符號、定位字元以及其他特殊字元。

三引號的文法是一對連續的單引號或者雙引號(通常都是成對的用)。

 >>> hi = ‘‘‘hi there‘‘‘>>> hi   # repr()‘hi\nthere‘>>> print hi  # str()hi there  
python的字串內建函數

字串方法是從python1.6到2.0慢慢加進來的——它們也被加到了Jython中。

這些方法實現了string模組的大部分方法,如下表所示列出了目前字串內建支援的方法,所有的方法都包含了對Unicode的支援,有一些甚至是專門用於Unicode的。

方法 描述

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 符號轉為空白格,預設的空格數 tabsize 是 8.

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

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

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)

Merges (concatenates)以 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()函數,不過是從右邊開始尋找.

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(num=string.count(‘\n‘))

按照行分隔,返回一個包含各行作為元素的列表,如果 num 指定則僅切片 num 個行.

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

string.isdecimal()

isdecimal()方法檢查字串是否只包含十進位字元。這種方法只存在於unicode對象。

  數字變為字串 str() FROM:http://www.w3cschool.cc/python/python-strings.html

Python中的字串處理

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.