Python中的基本數(shù)據(jù)類型講解
一、數(shù)據(jù)類型分類
1、按存值個(gè)數(shù)區(qū)分
- 單個(gè)值:數(shù)字,字符串
- 多個(gè)值(容器):列表,元組,字典,集合
2、按可變不可變區(qū)分
- 可變:列表[],字典{},集合{}
- 不可變:數(shù)字,字符串,元組()、bool,None
3、有序無序區(qū)分
- 有序(可按索引取值):字符串,列表,元組
- 無序:字典,集合
二、整型(int)
age = 18 # age=int(18) print(id(age))#<code>4530100848</code> print(type(age))#<class 'int'> print(age)#18
1、四種進(jìn)制表示形式
- 十進(jìn)制:1010, 99, -217
- 二進(jìn)制,以0b或0B開頭:0b010, -0B101
- 八進(jìn)制,以0o或0O開頭:0o123, -0O456
- 十六進(jìn)制,以0x或0X開頭:0x9a, –0X89
我們可以使用二進(jìn)制、十六進(jìn)制和八進(jìn)制來代表整數(shù)
number = 0b101011 # 二進(jìn)制 print(number) # 43 number = 0xA0F # 十六進(jìn)制 print(number) # 2575 number = 0o37 # 八進(jìn)制 print(number) # 31
2、int()方法
可將純數(shù)字的字符串轉(zhuǎn)為十進(jìn)制的整型
int(x):將x變成整數(shù),舍棄小數(shù)部分。
print(int("123")) # 123 x = int('111') print(type(x)) # <class 'int'> # print( int('11.1') ) # 報(bào)錯(cuò) print(int(123.45)) # 123
3、type和isinstance
內(nèi)置的type()函數(shù)可以用來查詢變量所指的對(duì)象類型。
a, b, c, d = 20, 5.5, True, 4 + 3j print(type(a), type(b), type(c), type(d)) # <class 'int'> <class 'float'> <class 'bool'> <class 'complex'>
此外還可以用isinstance來判斷:
a = 111 isinstance(a, int) # True
type和isinstance的區(qū)別在于:
- type()不會(huì)認(rèn)為子類是一種父類類型。
- isinstance()會(huì)認(rèn)為子類是一種父類類型。
class A: pass class B(A): pass isinstance(A(), A) # True type(A()) == A # True isinstance(B(), A) # True type(B()) == A # False
4、對(duì)象的創(chuàng)建和刪除
當(dāng)你指定一個(gè)值時(shí),Number對(duì)象就會(huì)被創(chuàng)建:
var = 2 var_a = var_b = 10
您可以通過使用del語句刪除單個(gè)或多個(gè)對(duì)象。
del語句的語法是:
del var1[, var2[, var3[...., varN]]]
例如:
del var del var_a, var_b print(var) # name 'var' is not defined
4、在交互模式中,最后被輸出的表達(dá)式結(jié)果被賦值給變量 _
例如:
>>> tax = 12.5 / 100
>>> price = 100.50
>>> price * tax
12.5625
>>> price + _
113.0625
>>> round(_, 2)
113.06
此處, _ 變量應(yīng)被用戶視為只讀變量。
5、注意:
- Python可以同時(shí)為多個(gè)變量賦值,如a, b = 1, 2。
- 一個(gè)變量可以通過賦值指向不同類型的對(duì)象。
- 數(shù)值的除法包含兩個(gè)運(yùn)算符:/ 返回一個(gè)浮點(diǎn)數(shù),// 返回一個(gè)整數(shù)。
- Python 可以使用 ** 操作來進(jìn)行冪運(yùn)算:5 ** 2 表示 5 的平方
- 在混合計(jì)算時(shí),Python會(huì)把整型轉(zhuǎn)換成為浮點(diǎn)數(shù)。
注意第3點(diǎn):// 得到的并不一定是整數(shù)類型的數(shù),它與分母分子的數(shù)據(jù)類型有關(guān)系。
print(7 // 2) # 3 print(7.0 // 2) # 3.0 print(7 // 2.0) # 3.0
三、浮點(diǎn)型(float)
salary = 2.1 # salary=float(2.1) print(id(salary))#<code>4569240656 </code> print(type(salary))#<code><class 'float'> </code> print(salary)# <code>2.1
1、float()方法
將純數(shù)字的字符串轉(zhuǎn)為浮點(diǎn)型數(shù)字。
float(x):將x變成浮點(diǎn)數(shù),增加小數(shù)部分。
print(float("1.23")) # 1.23 x = float('111') print(x) # 111.0 print(type(x)) # <class 'float'> x = float('11.1') print(x) # 11.1 print(type(x)) # <class 'float'> print(float(12)) # 12.0;
2、round()函數(shù)
1.浮點(diǎn)數(shù)間運(yùn)算存在不確定尾數(shù),一般發(fā)生在10的16次冪左右
2.round(x, d)函數(shù):對(duì)x四舍五入,d是小數(shù)截取位數(shù)
3.浮點(diǎn)數(shù)間運(yùn)算及比較,用round()函數(shù)輔助
0.1 + 0.2 == 0.3 # False
round(0.1+0.2, 1) == 0.3 # True
3、科學(xué)計(jì)數(shù)法
- 使用字母e或E作為冪的符號(hào),以10為基數(shù),
格式如下:<a>e<b>
,表示a*10b
- 例如:
4.3e-3
值為0.0043
,9.6E5
值為960000.0
4、數(shù)字運(yùn)算函數(shù)
abs(x):絕對(duì)值。x的絕對(duì)值。
print(abs(-10.01)) # 10.01
divmod(x,y):商余。(x//y, x%y),同時(shí)輸出商和余數(shù)。
print(divmod(10, 3)) # (3, 1)
pow(x, y[, z]):冪余。(x**y)%z,[..]表示參數(shù)z可省略。
print(pow(3, 2)) # 9 print(pow(3, 2, 2)) # 1 print(pow(3, pow(3, 2))) # 19683 print(pow(3, pow(3, 2), 10000)) # 9683
round(x[, d]):四舍五入。d是保留小數(shù)位數(shù),默認(rèn)值為0。
print(round(-10.123, 2)) # -10.12
max(x1,x2,?,xn):最大值。返回x1,x2,?,xnx1,x2,?,xn中的最大值,n不限。
print(max(1, 9, 5, 4, 3)) # 9
min(x1,x2,?,xn):最小值。返回x1,x2,?,xnx1,x2,?,xn中的最小值,n不限。
print(min(1, 9, 5, 4, 3)) # 1
以下為數(shù)學(xué)函數(shù),需要導(dǎo)入math模塊
exp(x):返回e的x次冪(ex)
import math print(math.exp(1)) # 2.718281828459045
fabs(x):返回?cái)?shù)字的絕對(duì)值
import math print(math.fabs(-10)) # 10.0
ceil(x):返回?cái)?shù)字的上入整數(shù)
import math print(math.ceil(4.1)) # 5
floor(x): 返回?cái)?shù)字的下舍整數(shù)
import math print(math.floor(4.9)) # 4
log(x):返回以e為基數(shù)的對(duì)象
import math print(math.log(math.e)) # 1.0 print(math.log(100, 10)) # 2.0
log10(x): 返回以10為基數(shù)的x的對(duì)數(shù)
import math print(math.log10(100)) # 2.0
modf(x):返回x的整數(shù)部分與小數(shù)部分,兩部分的數(shù)值符號(hào)與x相同,整數(shù)部分以浮點(diǎn)型表示。
import math print(math.modf(-100.1)) # (-0.09999999999999432, -100.0)
sqrt(x):返回?cái)?shù)字x的平方根。
import math print(math.sqrt(81)) # 9.0
四、復(fù)數(shù)型(complex)
a+bj
被稱為復(fù)數(shù),其中,a是實(shí)部,b是虛部
- real 獲得實(shí)部
- imag 獲得虛部
z = 1.23e-4 + 5.6e+89j print(z.real) # 0.000123 print(z.imag) # 5.6e+89
1、complex(x):將x變成復(fù)數(shù)
- complex(x) 將x轉(zhuǎn)換到一個(gè)復(fù)數(shù),實(shí)數(shù)部分為 x,虛數(shù)部分為 0。
- complex(x, y) 將 x 和 y 轉(zhuǎn)換到一個(gè)復(fù)數(shù),實(shí)數(shù)部分為 x,虛數(shù)部分為 y。x 和 y 是數(shù)字表達(dá)式。
print(complex(4)) # (4+0j)
五、布爾型(Bool)
True、False通常情況不會(huì)直接引用,需要使用邏輯運(yùn)算得到結(jié)果。
print(type(True))# <code><class 'bool'></code> print(True)# True
注意:Python中所有數(shù)據(jù)類型的值自帶布爾值。
如此多的數(shù)據(jù)類型中只需要記住只有0、None、空、False的布爾值為False,其余的為True。
print(bool(0)) # False print(bool(None)) # False print(bool('')) # False print(bool(False)) # False print(bool('nick')) # True print(bool(1 > 2)) # False print(bool(1 == 1)) # True
六、字符串(str)
字符串就是一串被串起來的字符,在單引號(hào)、雙引號(hào)或三引號(hào)內(nèi)包裹的一串字符。同時(shí)使用反斜杠 \ 轉(zhuǎn)義特殊字符。
name1 = 'nick' name2 = "egon" print(id(name1)) # <code>4418849624</code> print(type(name1))# <class 'str'> print(name1)# nick
需要注意的是:三引號(hào)內(nèi)的字符可以換行,而單雙引號(hào)內(nèi)的字符不可以。
name3 = """nick
egon"""
print(name3)
nick egon
1、特殊字符串:
- u'unicode': unicode編碼的字符串
- b'101': 二進(jìn)制編碼的字符串
轉(zhuǎn)義符:
Python 使用反斜杠(\)轉(zhuǎn)義特殊字符。
print("這里有個(gè)雙引號(hào)(\")") # 這里有個(gè)雙引號(hào)(")
轉(zhuǎn)義符形成一些組合,表達(dá)一些不可打印的含義:
\(在行尾時(shí)) :續(xù)行符
\\ :反斜杠符號(hào)
\' :?jiǎn)我?hào)
\" :雙引號(hào)
\a :響鈴
\b :退格(Backspace)
\000 :空
\n :換行
\v :縱向制表符
\t :橫向制表符
\r :回車(光標(biāo)移動(dòng)到本行首)
\f :換頁(yè)
\oyy :八進(jìn)制數(shù),yy 代表的字符,例如:\o12 代表?yè)Q行,其中 o 是字母,不是數(shù)字 0。
\xyy :十六進(jìn)制數(shù),yy代表的字符,例如:\x0a代表?yè)Q行
\other :其它的字符以普通格式輸出
- r'\n': 原生字符串,也就是說'\n'這是普通的兩個(gè)字符,并沒有換行的意思。
Python 使用反斜杠(\)轉(zhuǎn)義特殊字符,如果你不想讓反斜杠發(fā)生轉(zhuǎn)義,可以在字符串前面添加一個(gè) r,表示原始字符串:
print('Ru\noob') # Ru # oob print(r'Ru\noob') # Ru\noob
注意:
- Python 沒有單獨(dú)的字符類型,一個(gè)字符就是長(zhǎng)度為1的字符串。
- 反斜杠(\)可以作為續(xù)行符,表示下一行是上一行的延續(xù)。
- Python中的字符串有兩種索引方式,從左往右以0開始,從右往左以-1開始。
- Python中的字符串不能改變,向一個(gè)索引位置賦值,比如word[0] = 'm'會(huì)導(dǎo)致錯(cuò)誤。
2、字符串連接:x+y
連接兩個(gè)字符串x和y。如果字符串內(nèi)有引號(hào),則包裹字符串的引號(hào)和字符串內(nèi)部的引號(hào)不能相同。
msg2 = "my name is 'nick'" msg3 = 'my name is "nick"' print(msg2 + msg3) # my name is 'nick'my name is "nick"
3、字符串重復(fù):x * n
只能乘以數(shù)字。
name = 'nick ' print(name * 10)# <code>nick nick nick nick nick nick nick nick nick nick
4、字符串比較大小:x>y
按照ASCII碼比較.字符串的比較是字母的順序。
msg1 = 'hello' msg2 = 'z' print(msg1 > msg2) #False print('Z' > 'A') #True print('Z' > 'a') #False
5、可以使用str()、hex()、chr()、ord()方法轉(zhuǎn)為特殊字符串。
str(x):任意類型x所對(duì)應(yīng)的字符串形式
print(str(1.23)) # “1.23” print(str([1, 2])) # “[1, 2]”
hex(x) 或 oct(x):整數(shù)x的十六進(jìn)制或八進(jìn)制小寫形式字符串:
print(hex(425)) # "0x1a9" print(oct(425)) # "0o651"
chr(u):x為Unicode編碼,返回其對(duì)應(yīng)的字符
ord(x):x為字符,返回其對(duì)應(yīng)的Unicode編碼
print(chr(21704)) # "哈" print(ord('哈')) # "21704"
6、常用函數(shù):
1、str[n]:按索引取值
msg = 'hello nick' # 0123456789 # 索引序號(hào) print(msg[6] ) #索引為6: n print(msg[-3]) # 索引為-3: i
你可以截取字符串的一部分并與其他字段拼接,如下實(shí)例:
var1 = 'Hello World!' print("已更新字符串 : ", var1[:6] + 'Runoob!') # 已更新字符串 : Hello Runoob!
舉例:輸入整數(shù)對(duì)應(yīng)的星期字符串
weekStr = "一二三四五六日" weekId = eval(input("請(qǐng)輸入星期數(shù)字(1-7):")) print("星期" + weekStr[weekId - 1]) # 7 星期日
2、str[x:y:step]:切片(顧頭不顧尾,步長(zhǎng)) :
遵循左閉右開原則,str[0,2] 是不包含第 3 個(gè)字符的。
msg = 'hello_nick' # 0123456789 # 索引序號(hào) print(msg[3:] ) # 切片3-最后: lo_nick print(msg[3:8]) # 切片3-8: lo_ni print(msg[3:8:2] ) # 切片3-8,步長(zhǎng)為2: l_i print(msg[3::2]) # 切片3-最后,步長(zhǎng)為2: l_ik # 了解,步長(zhǎng)為正,從左到右;步長(zhǎng)為負(fù),從右到左 print(msg[:]) # 切片所有: hello_nick print(msg[::-1] ) # 反轉(zhuǎn)所有: kcin_olleh print(msg[-5:-2:1] ) # 切片-5--2: _ni print(msg[-2:-5:-1] ) # 切片-2--5: cin
3、len:長(zhǎng)度
msg = 'hello nick嗯' print(len(msg)) # 11
4、in、not in:成員運(yùn)算
msg = 'my name is nick, nick handsome' print('nick' in msg) # True print('jason' not in msg) # True print(not 'jason' in msg) # True
5、移除空白
- 移除左右空白:strip(chars)
- 移除左空白: lstrip(chars)
- 移除右空白:rstrip(chars)
name = '&&&n ick ' print(name.strip()) # &&&n ick,注意 strip()默認(rèn)為‘ ' print(name.strip('&')) # n ick ,strip并且不修改原值,新創(chuàng)建空間 print(name) # name: &&&n ick , print('*-& nick+'.strip('*-& +')) # nick
6、拆分,split,返回一個(gè)列表
- 拆分:split(str="", num=string.count(str)):以 str 為分隔符截取字符串,如果 num 有指定值,則僅截取 num+1 個(gè)子字符串,返回一個(gè)列表;
- 右拆分:rsplit
info = 'nick:male:19' info_list1 = info.split(':') # ['nick', 'male', '19'] info_list2 = info.split(':', 1) # ['nick', 'male:19'] print(info.rsplit(':', 1)) # ['nick:male', '19']。 從右開始切割
- 拆分行:splitlines([keepends]):按照行('\r', '\r\n', \n')分隔,返回一個(gè)包含各行作為元素的列表,如果參數(shù) keepends 為 False,不包含換行符,如果為 True,則保留換行符。
info = """aaa bbb ccc """ print(info.splitlines()) # ['aaa', 'bbb', 'ccc'] print(info.splitlines(True)) # ['aaa\n', 'bbb\n', 'ccc\n']
7、for循環(huán)
msg = 'hello nick' for i in msg: print(i) # 一個(gè)一個(gè)字符打印出來
8、大小寫,返回字符串的副本
- lower:轉(zhuǎn)成小寫
- upper:轉(zhuǎn)成小寫
name = 'Nick Chen' print(name.lower()) # nick chen print(name.upper()) # NICK CHEN
- captalize:將字符串的第一個(gè)字符轉(zhuǎn)換為大寫
- swapcase:將字符串中大寫轉(zhuǎn)換為小寫,小寫轉(zhuǎn)換為大寫
- title:返回"標(biāo)題化"的字符串,就是說所有單詞都是以大寫開始,其余字母均為小寫(見 istitle())
name = 'nick handsome sWAPCASE' print(name.capitalize()) # Nick handsome swapcase print(name.swapcase()) # NICK HANDSOME Swapcase 大小寫互轉(zhuǎn) print(name.title()) # Nick Handsome Swapcase
9、首末字符判斷
- startswith:首字符判斷
- endswith:末字符判斷
name = 'Nick Chen' print(name.startswith('Nick')) # True print(name.endswith('chen')) # False
10、join(seq):以此字符串作為分隔符,連接字符串。
以指定字符串作為分隔符,將 seq 中所有的元素(的字符串表示)合并為一個(gè)新的字符串
lis = ['nick', 'male', '19'] print(':'.join(lis)) # nick:male:19 print(",".join("12345")) # 1,2,3,4,5 str = "-" seq = ("a", "b", "c") # 字符串元組 print(str.join(seq)) # a-b-c
11、替換:replace
replace(old, new [, max]):把 將字符串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次。
name = 'nick shuai' print(name.replace('shuai', 'handsome')) # nick handsome
12、is***:數(shù)據(jù)類型判斷
salary = '111.1' print(salary.isdigit()) # False
- isdecimal(): 檢查字符串是否值包含十進(jìn)制字符,如果是返回True,否則返回False。
- isdigit(): 如果字符串只包含數(shù)字則返回True,否則返回False。
- isnumeric(): 如果字符串中只包含數(shù)字字符,則返回True,否則返回False。
- isalnum(): 如果字符串所有字符都是字母或數(shù)字則返回True,否則返回False。
- isalpha(): 如果字符串所有字符都是字母則返回True,否則返回False。
- isupper(): 如果字符串中(區(qū)分大小寫的)字符都是大寫,則返回True,否則返回False。
- islower(): 如果字符串中(區(qū)分大小寫的)字符都是小寫,則返回True,否則返回False。
- isspace(): 如果字符串中只包含空白,則返回True,否則返回False
- istitle(): 如果字符串是標(biāo)題類型的(見title()),則返回True,否則返回False。
num = "1" # unicode num.isdigit() # True num.isdecimal() # True num.isnumeric() # True num = "1" # 全角 num.isdigit() # True num.isdecimal() # True num.isnumeric() # True num = b"1" # byte num.isdigit() # True num.isdecimal() # 屬性錯(cuò)誤 'bytes' object has no attribute 'isdecimal' num.isnumeric() # 屬性錯(cuò)誤 'bytes' object has no attribute 'isnumeric' num = "IV" # 羅馬數(shù)字 num.isdigit() # True num.isdecimal() # False num.isnumeric() # True num = "四" # 漢字 num.isdigit() # False num.isdecimal() # False num.isnumeric() # True
13、unicodeData
- 1.unicodedata.lookup():通過索引中的名稱查找相應(yīng)的字符
- 2.unicodedata.name():通過字符查找名稱,與unicodedata.lookup()相反
- 4.unicodedata.digit():把一個(gè)合法的數(shù)字字符串轉(zhuǎn)換為數(shù)字值
- 3.unicodedata.decimal():返回表示數(shù)字字符的數(shù)值
- 5.unicodedata.numeric():把一個(gè)表示數(shù)字的字符串轉(zhuǎn)換為浮點(diǎn)數(shù)返回,與unicodedata.digit()不同的是:它可以任意表示數(shù)值的字符都可以,不僅僅限于0到9的字符
- 6.unicodedata.category():把一個(gè)字符返回它在UNICODE里分類的類型
import unicodedata unicodedata.digit("2") # 2 unicodedata.decimal("2") # 2 unicodedata.numeric("2") # 2.0 unicodedata.digit("2") # 2 unicodedata.decimal("2") # 2 unicodedata.numeric("2") # 2.0 unicodedata.digit(b"3") # TypeError: must be str, not bytes unicodedata.decimal(b"3") # TypeError: must be str, not bytes unicodedata.numeric(b"3") # TypeError: must be str, not bytes unicodedata.digit("Ⅷ") # ValueError: not a digit unicodedata.decimal("Ⅷ") # ValueError: not a decimal
unicodedata.numeric("Ⅷ") # 8.0
unicodedata.digit("四") # ValueError: not a digit unicodedata.decimal("四") # ValueError: not a decimal
unicodedata.numeric("四") # 4.0
14、查找:find、 index
- find(str, beg=0, end=len(string)):檢測(cè) str 是否包含在字符串中。如果指定范圍 beg 和 end ,則檢查是否包含在指定范圍內(nèi),如果包含返回開始的索引值,否則返回-1。
- rfind(str, beg=0,end=len(string)):類似于 find()函數(shù),不過是從右邊開始查找
- index(str, beg=0, end=len(string)):跟find()方法一樣,只不過如果str不在字符串中會(huì)報(bào)一個(gè)異常
- rindex:類似于 index(),不過是從右邊開始
- count(str, beg= 0,end=len(string)):返回 str 在 string 里面出現(xiàn)的次數(shù),如果 beg 或者 end 指定則返回指定范圍內(nèi) str 出現(xiàn)的次數(shù)
msg = 'my name is tank, tank shi sb, hha' print(msg.find('tank')) # 11 print(msg.find('tank', 0, 3)) # -1,找不到返回-1 print(msg.rfind('tank')) # 17,找不到返回-1 print(msg.index('tank')) # 11.找不到報(bào)錯(cuò) print(msg.rindex('tank')) # 17 找不到報(bào)錯(cuò) print(msg.count('tank')) # 2
15、填充
- center(width[, fillchar]):返回一個(gè)原字符串居中對(duì)齊,并使用 fillchar 填充至長(zhǎng)度。width 的新字符串,fillchar 默認(rèn)為空格。
- ljust(width[, fillchar]):返回一個(gè)原字符串左對(duì)齊,并使用 fillchar 填充至長(zhǎng)度。
- rjust(width[, fillchar]):返回一個(gè)原字符串右對(duì)齊,并使用空格填充至長(zhǎng)度 width 的新字符串。
- zfill(width):返回長(zhǎng)度為 width 的字符串,原字符串 string 右對(duì)齊,前面填充0。
print('info nick'.center(20, '*')) # *****info nick****** print('info nick'.ljust(20, '*')) # info nick*********** print('info nick'.rjust(20, '*')) # ***********info nick print('info nick'.zfill(20)) # 00000000000info nick, 默認(rèn)用0填充
16、expandtabs(tabsize=8):把字符串中的 tab 符號(hào)轉(zhuǎn)為空格
tab 符號(hào)默認(rèn)的空格數(shù)是 8 。
print('a\tb\tc\t') # a b c ,默認(rèn)制表符8個(gè)空格 print('a\tb\tc\t'.expandtabs(10)) # a b c .
17、encode、decode:字符編碼解碼
Python3中字符串默認(rèn)為Unicode編碼。
str類型的數(shù)據(jù)可以編碼成其他字符編碼的格式,編碼的結(jié)果為bytes類型。
# coding:gbk x = '上' # 當(dāng)程序執(zhí)行時(shí),無需加u,'上'也會(huì)被以Unicode形式保存新的內(nèi)存空間中, print(type(x)) # <class 'str'> # x可以直接encode成任意編碼格式 print(x.encode('gbk')) # b'\xc9\xcf' print(type(x.encode('gbk'))) # <class 'bytes'>
- str.encode(encoding='UTF-8',errors='strict'):以 encoding 指定的編碼格式編碼字符串,如果出錯(cuò)默認(rèn)報(bào)一個(gè)ValueError 的異常,除非 errors 指定的是'ignore'或者'replace'
- bytes.decode(encoding="utf-8", errors="strict"):解碼給定的 bytes 對(duì)象,這個(gè) bytes 對(duì)象可以由 str.encode() 來編碼返回。
a = "asdfasdfffsa師德師風(fēng)的" b = a.encode(encoding='UTF-8', errors='strict') print(type(b)) # <class 'bytes'> print(b) # b'asdfasdfffsa\xe5\xb8\x88\xe5\xbe\xb7\xe5\xb8\x88\xe9\xa3\x8e\xe7\x9a\x84' c = b.decode(encoding="utf-8", errors="strict") print(type(c)) # <class 'str'> print(c) # asdfasdfffsa師德師風(fēng)的
18、字符串與列表,元組的互相轉(zhuǎn)換。
1、字符串轉(zhuǎn)換為列表:for循環(huán)
var='菜鳥教程' list=[] list= [i for i in var]
2、列表轉(zhuǎn)化為字符串:使用 join 來實(shí)現(xiàn):
var1=' ,'.join(list)
3、字符串轉(zhuǎn)化為元組,使用 tuple() 函數(shù)。
tup=tuple(var)
七、其他數(shù)據(jù)類型
1、分?jǐn)?shù)類型:Fraction
構(gòu)造函數(shù):
- class fractions.Fraction(numerator=0, denominator=1)
- class fractions.Fraction(int|float|str|Decimal|Fraction)
可以同時(shí)提供分子(numerator)和分母(denominator)給構(gòu)造函數(shù)用于實(shí)例化Fraction類,但兩者必須同時(shí)是int類型或者numbers.Rational類型,否則會(huì)拋出類型錯(cuò)誤。當(dāng)分母為0,初始化的時(shí)候會(huì)導(dǎo)致拋出異常ZeroDivisionError。
分?jǐn)?shù)類型:
from fractions import Fraction x = Fraction(1, 3) y = Fraction(4, 6) print(x + y) # 1 print(1 / 3 + 4 / 6) # 1.0 print(Fraction('.25')) # 1/4
浮點(diǎn)數(shù)與分?jǐn)?shù)的轉(zhuǎn)換:
from fractions import Fraction f = 2.5 z = Fraction(*f.as_integer_ratio()) print(z) # 5/2 x = Fraction(1, 3) print(float(x)) # 0.3333333333333333
2、小數(shù):Decimal類型
decimal 模塊提供了一個(gè) Decimal 數(shù)據(jù)類型用于浮點(diǎn)數(shù)計(jì)算,擁有更高的精度。
import decimal decimal.localcontext().prec= 4 # 指定精度(4位小數(shù)) print(decimal.Decimal(1) / decimal.Decimal(7)) # 0.1429 with decimal.localcontext() as ctx: # 小數(shù)上下文管理器 ctx.prec = 2 print(decimal.Decimal('1.00') / decimal.Decimal('3.00')) # 0.33
到此這篇關(guān)于Python數(shù)據(jù)類型的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Tensorflow設(shè)置顯存自適應(yīng),顯存比例的操作
今天小編就為大家分享一篇Tensorflow設(shè)置顯存自適應(yīng),顯存比例的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02在matplotlib中改變figure的布局和大小實(shí)例
這篇文章主要介紹了在matplotlib中改變figure的布局和大小實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04python實(shí)現(xiàn)根據(jù)文件格式分類
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)根據(jù)文件格式分類,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10Python實(shí)現(xiàn)刪除重復(fù)視頻文件的方法詳解
這篇文章主要為大家詳細(xì)介紹了如何利用Python實(shí)現(xiàn)刪除重復(fù)視頻文件功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定幫助,需要的可以參考一下2022-10-10關(guān)于adfuller函數(shù)返回值的參數(shù)說明與記錄
這篇文章主要介紹了關(guān)于adfuller函數(shù)返回值的參數(shù)說明與記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11設(shè)計(jì)模式中的原型模式在Python程序中的應(yīng)用示例
這篇文章主要介紹了設(shè)計(jì)模式中的原型模式在Python程序中的應(yīng)用示例,文中主要強(qiáng)調(diào)了對(duì)淺拷貝和深拷貝在對(duì)象復(fù)制時(shí)的使用,需要的朋友可以參考下2016-03-03Django在Win7下的安裝及創(chuàng)建項(xiàng)目hello word簡(jiǎn)明教程
這篇文章主要介紹了Django在Win7下的安裝及創(chuàng)建項(xiàng)目hello word,需要的朋友可以參考下2014-07-07Python實(shí)現(xiàn)桶排序與快速排序算法結(jié)合應(yīng)用示例
這篇文章主要介紹了Python實(shí)現(xiàn)桶排序與快速排序算法結(jié)合應(yīng)用,結(jié)合實(shí)例形式分析了Python快速排序及桶排序結(jié)合應(yīng)用的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-11-11基于Python實(shí)現(xiàn)圖片一鍵切割九宮格的工具
有時(shí)候發(fā)微博時(shí)候,需要裁切圖片為九宮格,但是ps或者其他工具都太麻煩。本文就來用Python編寫一個(gè)一鍵切割九宮格的工具,希望對(duì)大家有所幫助2023-03-03