類別
可使用type()查看
內建 [ 布爾:bool (Boolen) 字串:str (String) 數字:int (Integer) 小數:float 列表:list 元祖:tuple 字典:dict ]
亦可用class宣告新類別
布爾值 (用於比較、邏輯、成員判定之運算)
以 1=True, 0=False 紀錄於記憶體中
資料判定上,有東西 or 判定為真=True,沒東西( "", [ ], ( ), { }, 0 )or判定為假=False
有邏輯運算 ( and or not)
有關係符 ( < (小於) <= (小於等於) == (等於) >= (大於等於) > (大於) != or <> (不等於) )
字串 (用於算術、賦值運算)
常用之方法: join split strip find upper lower replace
索引與獲取 test [位置]
片段 test [ 起始 : 終點之前]
長度 len( 字符串 )
大小写转换
str.capitalize() 首字母大寫
str.casefold() 轉為對應之小寫(含符號式小寫)
str.sapcase()
str.lower() 全英文小寫
str.upper() 全英文大寫
str.title() 每個字首都轉大寫
def capitalize(self, *args, **kwargs):
def lower(self, *args, **kwargs):
def upper(self, *args, **kwargs):
def casefold(self, *args, **kwargs):
def swapcase(self, *args, **kwargs):
def title()(self, *args, **kwargs):
判定系列
str.islower() 是否為全英文小寫 str.isuuper 是否為全英文大寫
str.isalnum() 是否只為數字or字符(無空白) str.isalpha() 是否只為字符
str.isdicimal() 是否為十進制的數字 str.isdigit() 是否為數字 str.isnumeric() 是否為數字(含中文數字)
str.isidentifier() 是否為字母、數字、下划線
str.isprintable() 是否有不可見的功能字符(ex: , 等)
str.isspace() 是否全是空白格
str.istitle() 是否字首都為大寫
def isupper(self, *args, **kwargs):
def islower(self, *args, **kwargs):
def isalnum(self, *args, **kwargs):
def isalpha(self, *args, **kwargs):def isdecimal(self, *args, **kwargs): def isdigit(self, *args, **kwargs): def isidentifier(self, *args, **kwargs): def isnumeric(self, *args, **kwargs): def isprintable(self, *args, **kwargs): def isspace(self, *args, **kwargs): def istitle(self, *args, **kwargs):
字符串格式输出
str.Center( width[, fillchar] ) 設定寬度並將物件置中,其於以填充物填補,若無標示則默認為space
str.ljust( width[, fillchar] ) 設定寬度並將物件置左,其於以填充物填補,若無標示則默認為space
str.rjust( width[, fillchar] ) 設定寬度並將物件置右,其於以填充物填補,若無標示則默認為space
str.zfill( width ) 設定寬度並將物件左側以0塞滿
def center(self, *args, **kwargs):
def ljust(self, *args, **kwargs):
def rjust(self, *args, **kwargs):
def zfill(self, *args, **kwargs):
str.format(*args, **kwargs)
def format(self, *args, **kwargs):
# default arguments print("Hello {}, your balance is {}.".format("Adam", 230.2346)) # positional arguments print("Hello {0}, your balance is {1}.".format("Adam", 230.2346)) # keyword arguments print("Hello {name}, your balance is {blc}.".format(name="Adam", blc=230.2346)) # mixed arguments print("Hello {0}, your balance is {blc}.".format("Adam", blc=230.2346))
#dictionry
print("Hello {0}, your balance is {blc}.".format(**{"Adam", blc=230.2346})
亦可作為數值格式調整
: 号后面带填充的字符,只能是一个字符,不指定则默认是用空格填
^, <, > 分别是居中、左对齐、右对齐(默認),后面带宽度 (ex {:^10d} )
.nf 表示至小數下第n位
正数前显示 +,负数前显示 -; (空格)表示在正数前加空格 (ex: {:+.2f} )
b、d、o、x 分别是二进制、十进制、八进制、十六进制
# integer numbers with minimum width print("{:5d}".format(12)) # width doesn't work for numbers longer than padding print("{:2d}".format(1234)) # padding for float numbers print("{:8.3f}".format(12.2346)) # integer numbers with minimum width filled with zeros print("{:05d}".format(12)) # padding for float numbers filled with zeros print("{:08.3f}".format(12.2346))
12 1234 12.235 00012 0012.235
str.format_map(mapping) mapping
是一个字典对象
def format_map(self, mapping):
point = {'x':4,'y':-5} print('{x} {y}'.format_map(point))
str.expandtabs(tabsize=8)
用指定的空格替代横向制表符,使得相邻字符串之间的间距保持在指定的空格数以内,可搭配 斷句、 換行使用。
def expandtabs(self, *args, **kwargs):
字符串搜索定位
str.count( "目標"[, 起始=none, 結束=none] ) 尋找子序列的出現次數,不可為int(數字) 左側依序以0開始,往右隨之遞增,最右側起始為 -1,往左隨之遞減 (end位置數值不包含本身)
def count(self, sub, start=None, end=None)
str,endwith( "目標"[, 起始=none, 結束=none] ) 是否以目標結尾,不可為int(數字) 左側依序以0開始,往右隨之遞增,最右側起始為 -1,往左隨之遞減 (end位置數值不包含本身)
str.startwith( "目標"[, 起始=none, 結束=none] ) 是否以目標開頭,不可為int(數字) 左側依序以0開始,往右隨之遞增,最右側起始為 -1,往左隨之遞減 (end位置數值不包含本身)
def endswith(self, suffix, start=None, end=None): def startswith(self, prefix, start=None, end=None):
str.find( "目標"[, 起始=none, 結束=none] ) 從左側找起,目標為第幾個,不可為int(數字) 左側依序以0開始,往右隨之遞增,最右側起始為 -1,往左隨之遞減 (end位置數值不包含本身,若無發現目標則以-1表示)
str.rfind( "目標"[, 起始=none, 結束=none] ) 從右側找起,目標為第幾個,不可為int(數字 左側依序以0開始,往右隨之遞增,最右側起始為 -1,往左隨之遞減 (end位置數值不包含本身,若無發現目標則以-1表示)
def find(self, sub, start=None, end=None): def rfind(self, sub, start=None, end=None):
str.index( "目標"[, 起始=none, 結束=none] ) 約等於find,但無發現時程式無法執行
str.rindex( "目標"[, 起始=none, 結束=none] ) 約等於rfind,但無發現時程式無法執行
def index(self, sub, start=None, end=None): def rindex(self, sub, start=None, end=None):
字符串搜索与替换
str.replace(old, new[, count]) count默認為全部
def replace(self, *args, **kwargs):
str.strip([chars]) 依序從兩端去除指定物內的子集物,直到無法刪除則停止,chars值若為none則去除所有空白格及 、
str.lstrip([chars]) 依序從左側去除指定物內的子集物,直到無法刪除則停止,chars值若為none則去除所有空白格及 、
str.rstrip([chars]) 依序從右側去除指定物內的子集物,直到無法刪除則停止,chars值若為none則去除所有空白格及 、
def strip(self, *args, **kwargs): def lstrip(self, *args, **kwargs):
def rstrip(self, *args, **kwargs):
static str.maketrans(x[, y[, z]]) 對應表
str.translate(table) 制換
def maketrans(self, *args, **kwargs):
def translate(self, *args, **kwargs):
maketrans可以為直接以( )指定,但前後對應表需具有相同字元數,亦可用字典帶入參數
a = 'dobi is a dog' table = str.maketrans('dobi', 'alph') a.translate(table) # 'alph hs a alg'
(d=>a o=>l b=>p i =>h) table = str.maketrans('dobi', 'alph', 'o') a.translate(table) # 'aph hs a ag'
(第三個參數,表示將原先的o,改對應成none)
字符串的联合与分割
str.partition(sep) 從左側找到第一個符合的目標後,以目標作前後切割,獲得三份資料
str.rpartition(sep) 從右側找到第一個符合的目標後,以目標作前後切割,獲得三份資料
str.split(sep=None, maxsplit=-1) 從左側找到第一個符合的目標後,將目標切除,獲得兩份資料,目標若無指定則默認為全數切分
str.rsplit(sep=None, maxsplit=-1) 從右側找到第一個符合的目標後,將目標切除,獲得兩份資料,目標若無指定則默認為全數切分
str.splitlines([keepends]) 從左側起找行界符,如果keepend為True則保留,若無指定則默認將行界符切除
def partition(self, *args, **kwargs):
def rpartition(self, *args, **kwargs):
def split(self, *args, **kwargs):
def rsplit(self, *args, **kwargs): def splitlines(self, *args, **kwargs):
>>> 'ab c de fg kl '.splitlines() ['ab c', '', 'de fg', 'kl'] >>> 'ab c de fg kl '.splitlines(keepends=True) ['ab c ', ' ', 'de fg ', 'kl ']
str.join(iterable) 用指定的字符串,连接元素为字符串的可迭代对象。若為字符串,則每個字符間均插入,若為 "abc" , "123" 等()[]{}集合,則將子集作連結 abc_123
def join(self, ab=None, pq=None, rs=None):
其他
str.encode(encoding=”utf-8″, errors=”strict”)
def encode(self, *args, **kwargs):