08 基本資料型別及內建方法
阿新 • • 發佈:2020-11-05
目錄:
- 引子
- 數字型別int與float
- 定義
- 型別轉換
- 使用
- 字串
- 定義
- 型別轉換
- 使用
- 優先掌握的操作
- 需要掌握的操作
- 瞭解操作
- 列表
- 定義
- 型別轉換
- 使用
- 優先掌握的操作
- 瞭解操作
- 元組
- 作用
- 定義方法
- 型別轉換
- 使用
- 字典
- 定義
- 型別轉換
- 使用
- 優先掌握的操作
- 需要掌握的操作
- 集合
- 作用
- 定義
- 型別轉換
- 使用
- 關係運算
- 去重
- 其他操作
- 練習
- 可變型別和不可變型別
- 資料型別總結
一 引子
資料型別是用來記錄事物狀態的,而事物的狀態是不斷變化的(如:一個人年齡的增長(操作int型別) ,單個人名的修改(操作str型別),學生列表中增加學生(操作list型別)等),這意味著我們在開發程式時需要頻繁對資料進行操作,為了提升我們的開發效率, python針對這些常用的操作,為每一種資料型別內建了一系列方法。本章的主題就是帶大家詳細瞭解下它們,以及每種資料型別的詳細定義、型別轉換。
二 數字型別int與float
2.1 定義
# 1、定義:
# 1.1 整型int的定義
age=10 # 本質age = int(10)
# 1.2 浮點型float的定義
salary=3000.3 # 本質salary=float(3000.3)
# 注意:名字+括號的意思就是呼叫某個功能,比如
# print(...)呼叫列印功能
# int(...)呼叫建立整型資料的功能
# float(...)呼叫建立浮點型資料的功能
2.2 型別轉換
# 1、資料型別轉換
# 1.1 int可以將由純整數構成的字串直接轉換成整型,若包含其他任意非整數符號,則會報錯
>>> s = '123'
>>> res = int(s)
>>> res,type(res)
(123, <class 'int'>)
>>> int('12.3') # 錯誤演示:字串內包含了非整數符號.
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: '12.3'
# 1.2 進位制轉換
# 十進位制轉其他進位制
>>> bin(3)
'0b11'
>>> oct(9)
'0o11'
>>> hex(17)
'0x11'
# 其他進位制轉十進位制
>>> int('0b11',2)
3
>>> int('0o11',8)
9
>>> int('0x11',16)
17
# 1.3 float同樣可以用來做資料型別的轉換
>>> s = '12.3'
>>> res=float(s)
>>> res,type(res)
(12.3, <class 'float'>)
2.3 使用
數字型別主要就是用來做數學運算與比較運算,因此數字型別除了與運算子結合使用之外,並無需要掌握的內建方法
三 字串
3.1 定義:
# 定義:在單引號\雙引號\三引號內包含一串字元
name1 = 'jason' # 本質:name = str('任意形式內容')
name2 = "lili" # 本質:name = str("任意形式內容")
name3 = """ricky""" # 本質:name = str("""任意形式內容""")
3.2 型別轉換
# 資料型別轉換:str()可以將任意資料型別轉換成字串型別,例如
>>> type(str([1,2,3])) # list->str
<class 'str'>
>>> type(str({"name":"jason","age":18})) # dict->str
<class 'str'>
>>> type(str((1,2,3))) # tuple->str
<class 'str'>
>>> type(str({1,2,3,4})) # set->str
<class 'str'>
3.3 使用
3.3.1 優先掌握的操作
>>> str1 = 'hello python!'
# 1.按索引取值(正向取,反向取):
# 1.1 正向取(從左往右)
>>> str1[6]
p
# 1.2 反向取(負號表示從右往左)
>>> str1[-4]
h
# 1.3 對於str來說,只能按照索引取值,不能改
>>> str1[0]='H' # 報錯TypeError
# 2.切片(顧頭不顧尾,步長)
# 2.1 顧頭不顧尾:取出索引為0到8的所有字元
>>> str1[0:9]
hello pyt
# 2.2 步長:0:9:2,第三個引數2代表步長,會從0開始,每次累加一個2即可,所以會取出索引0、2、4、6、8的字元
>>> str1[0:9:2]
hlopt
# 2.3 反向切片
>>> str1[::-1] # -1表示從右往左依次取值
!nohtyp olleh
# 3.長度len
# 3.1 獲取字串的長度,即字元的個數,但凡存在於引號內的都算作字元)
>>> len(str1) # 空格也算字元
13
# 4.成員運算 in 和 not in
# 4.1 int:判斷hello 是否在 str1裡面
>>> 'hello' in str1
True
# 4.2 not in:判斷tony 是否不在 str1裡面
>>> 'tony' not in str1
True
# 5.strip移除字串首尾指定的字元(預設移除空格)
# 5.1 括號內不指定字元,預設移除首尾空白字元(空格、\n、\t)
>>> str1 = ' life is short! '
>>> str1.strip()
life is short!
# 5.2 括號內指定字元,移除首尾指定的字元
>>> str2 = '**tony**'
>>> str2.strip('*')
tony
# 6.切分split
# 6.1 括號內不指定字元,預設以空格作為切分符號
>>> str3='hello world'
>>> str3.split()
['hello', 'world']
# 6.2 括號內指定分隔字元,則按照括號內指定的字元切割字串
>>> str4 = '127.0.0.1'
>>> str4.split('.')
['127', '0', '0', '1'] # 注意:split切割得到的結果是列表資料型別
# 7.迴圈
>>> str5 = '今天你好嗎?'
>>> for line in str5: # 依次取出字串中每一個字元
... print(line)
...
今
天
你
好
嗎
?
3.3.2 需要掌握的操作
1.strip, lstrip, rstrip
>>> str1 = '**tony***'
>>> str1.strip('*') # 移除左右兩邊的指定字元
'tony'
>>> str1.lstrip('*') # 只移除左邊的指定字元
tony***
>>> str1.rstrip('*') # 只移除右邊的指定字元
**tony
2.lower(),upper()
>>> str2 = 'My nAme is tonY!'
>>> str2.lower() # 將英文字串全部變小寫
my name is tony!
>>> str2.upper() # 將英文字串全部變大寫
MY NAME IS TONY!
3.startswith,endswith
>>> str3 = 'tony jam'
# startswith()判斷字串是否以括號內指定的字元開頭,結果為布林值True或False
>>> str3.startswith('t')
True
>>> str3.startswith('j')
False
# endswith()判斷字串是否以括號內指定的字元結尾,結果為布林值True或False
>>> str3.endswith('jam')
True
>>> str3.endswith('tony')
False
4.格式化輸出之format
之前我們使用%s來做字串的格式化輸出操作,在傳值時,必須嚴格按照位置與%s一一對應,而字串的內建方法format則提供了一種不依賴位置的傳值方式
案例:
# format括號內在傳引數時完全可以打亂順序,但仍然能指名道姓地為指定的引數傳值,name=‘tony’就是傳給{name}
>>> str4 = 'my name is {name}, my age is {age}!'.format(age=18,name='tony')
>>> str4
'my name is tony, my age is 18!'
>>> str4 = 'my name is {name}{name}{name}, my age is {name}!'.format(name='tony', age=18)
>>> str4
'my name is tonytonytony, my age is tony!'
format的其他使用方式(瞭解)
# 類似於%s的用法,傳入的值會按照位置與{}一一對應
>>> str4 = 'my name is {}, my age is {}!'.format('tony', 18)
>>> str4
my name is tony, my age is 18!
# 把format傳入的多個值當作一個列表,然後用{索引}取值
>>> str4 = 'my name is {0}, my age is {1}!'.format('tony', 18)
>>> str4
my name is tony, my age is 18!
>>> str4 = 'my name is {1}, my age is {0}!'.format('tony', 18)
>>> str4
my name is 18, my age is tony!
>>> str4 = 'my name is {1}, my age is {1}!'.format('tony', 18)
>>> str4
my name is 18, my age is 18!
5.split,rsplit
# split會按照從左到右的順序對字串進行切分,可以指定切割次數
>>> str5='C:/a/b/c/d.txt'
>>> str5.split('/',1)
['C:', 'a/b/c/d.txt']
# rsplit剛好與split相反,從右往左切割,可以指定切割次數
>>> str5='a|b|c'
>>> str5.rsplit('|',1)
['a|b', 'c']
6.join
# 從可迭代物件中取出多個字串,然後按照指定的分隔符進行拼接,拼接的結果為字串
>>> '%'.join('hello') # 從字串'hello'中取出多個字串,然後按照%作為分隔符號進行拼接
'h%e%l%l%o'
>>> '|'.join(['tony','18','read']) # 從列表中取出多個字串,然後按照*作為分隔符號進行拼接
'tony|18|read'
7.replace
# 用新的字元替換字串中舊的字元
>>> str7 = 'my name is tony, my age is 18!' # 將tony的年齡由18歲改成73歲
>>> str7 = str7.replace('18', '73') # 語法:replace('舊內容', '新內容')
>>> str7
my name is tony, my age is 73!
# 可以指定修改的個數
>>> str7 = 'my name is tony, my age is 18!'
>>> str7 = str7.replace('my', 'MY',1) # 只把一個my改為MY
>>> str7
'MY name is tony, my age is 18!'
8.isdigit
# 判斷字串是否是純數字組成,返回結果為True或False
>>> str8 = '5201314'
>>> str8.isdigit()
True
>>> str8 = '123g123'
>>> str8.isdigit()
False
3.3.3 瞭解操作
# 1.find,rfind,index,rindex,count
# 1.1 find:從指定範圍內查詢子字串的起始索引,找得到則返回數字1,找不到則返回-1
>>> msg='tony say hello'
>>> msg.find('o',1,3) # 在索引為1和2(顧頭不顧尾)的字元中查詢字元o的索引
1
# 1.2 index:同find,但在找不到時會報錯
>>> msg.index('e',2,4) # 報錯ValueError
# 1.3 rfind與rindex:略
# 1.4 count:統計字串在大字串中出現的次數
>>> msg = "hello everyone"
>>> msg.count('e') # 統計字串e出現的次數
4
>>> msg.count('e',1,6) # 字串e在索引1~5範圍內出現的次數
1
# 2.center,ljust,rjust,zfill
>>> name='tony'
>>> name.center(30,'-') # 總寬度為30,字串居中顯示,不夠用-填充
-------------tony-------------
>>> name.ljust(30,'*') # 總寬度為30,字串左對齊顯示,不夠用*填充
tony**************************
>>> name.rjust(30,'*') # 總寬度為30,字串右對齊顯示,不夠用*填充
**************************tony
>>> name.zfill(50) # 總寬度為50,字串右對齊顯示,不夠用0填充
0000000000000000000000000000000000000000000000tony
# 3.expandtabs
>>> name = 'tony\thello' # \t表示製表符(tab鍵)
>>> name
tony hello
>>> name.expandtabs(1) # 修改\t製表符代表的空格數
tony hello
# 4.captalize,swapcase,title
# 4.1 captalize:首字母大寫
>>> message = 'hello everyone nice to meet you!'
>>> message.capitalize()
Hello everyone nice to meet you!
# 4.2 swapcase:大小寫翻轉
>>> message1 = 'Hi girl, I want make friends with you!'
>>> message1.swapcase()
hI GIRL, i WANT MAKE FRIENDS WITH YOU!
#4.3 title:每個單詞的首字母大寫
>>> msg = 'dear my friend i miss you very much'
>>> msg.title()
Dear My Friend I Miss You Very Much
# 5.is數字系列
#在python3中
num1 = b'4' #bytes
num2 = u'4' #unicode,python3中無需加u就是unicode
num3 = '四' #中文數字
num4 = 'Ⅳ' #羅馬數字
#isdigt:bytes,unicode
>>> num1.isdigit()
True
>>> num2.isdigit()
True
>>> num3.isdigit()
False
>>> num4.isdigit()
False
#isdecimal:uncicode(bytes型別無isdecimal方法)
>>> num2.isdecimal()
True
>>> num3.