1. 程式人生 > >【語法02】Python資料型別

【語法02】Python資料型別

數字(Number)

# 使用del語句刪除一些數字物件的引用
# del var1[,var2[,var3[....,varN]]]]

# 通過使用del語句刪除單個或多個物件的引用
# del var 
# del var_a, var_b

#Python 支援三種不同的數值型別:
#整型(Int) - 通常被稱為是整型或整數,是正或負整數,不帶小數點。Python3 整型是沒有限制大小的,可以當作 Long 型別使用,所以 Python3 沒有 Python2 的 Long 型別。
#浮點型(float) - 浮點型由整數部分與小數部分組成,浮點型也可以使用科學計數法表示(2.5e2 = 2.5 x 102 = 250)
#複數( (complex)) - 複數由實數部分和虛數部分構成,可以用a + bj,或者complex(a,b)表示, 複數的實部a和虛部b都是浮點型。 #十六進位制和八進位制代表整數: number = 0xA0F #十六進位制 print(number) number = 0o37 #八進位制 print(number) #Python支援複數,複數由實數部分和虛數部分構成,可以用a + bj,或者complex(a,b)表示, 複數的實部a和虛部b都是浮點型。
2575
31
#Python數字型別轉換

# int(x)將x轉換為一個整數
# float(x)將x轉換為一個浮點數
# complex(x) 將x轉換到一個複數,實數部分為 x,虛數部分為 0。 # complex(x, y) 將 x 和 y 轉換到一個複數,實數部分為 x,虛數部分為 y。x 和 y 是數字表達式。 a = complex(3) print(a) a = complex(4,5) print(a)
(3+0j)
(4+5j)
# Python數字運算
print(17 / 3)
print(17 // 3)

# //得到的不一定是整數型別的數,它與分母分子的資料型別有關係
print(7 / 2)
print(7 // 2)
print(7.0 // 2)
print(7 // 2.0)

#不同型別的數混合運算時會將整數轉換為浮點數:
print(3 * 3.75 / 1.5)
5.666666666666667
5
3.5
3
3.0
3.0
7.5
# 在互動模式中,最後被輸出的表示式結果被賦值給變數 _ 。
'''
>>> tax = 12.5 / 100
>>> price = 100.50
>>> price * tax
12.5625
>>> price + _
113.0625
>>> round(_, 2)
113.06
'''
#數學函式

import math

print(abs(-2.5))

print(math.ceil(2.5)) # 返回數字的上入整數,如math.ceil(4.1) 返回 5
print(math.ceil(-2.5))

print(math.exp(1)) # 返回e的x次冪(ex)

print(math.fabs(-2)) # 返回數字的絕對值

print(math.floor(2.5)) # 返回數字的下舍整數

print(math.log(100,10)) # 如math.log(math.e)返回1.0,math.log(100,10)返回2.0
print(math.log(2))# ln()

print(math.log10(1000))

print(max(2,3,5))

print(min(2,3,5))

print(math.modf(3.75))# 返回x的整數部分與小數部分,兩部分的數值符號與x相同,整數部分以浮點型表示。
print(math.modf(-3.75))

print(pow(2,3.7))

print(round(3.756,2)) #返回浮點數x的四捨五入值,如給出n值,則代表舍入到小數點後的位數。
print(round(4.522222,1))

print(math.sqrt(2))
2.5
3
-2
2.718281828459045
2.0
2
2.0
0.6931471805599453
3.0
5
2
(0.75, 3.0)
(-0.75, -3.0)
12.99603834169977
3.76
4.5
1.4142135623730951
# 隨機數函式

import random

print(random.choice(range(10)))#在序列的元素中隨機挑選一個元素
a = [1,2,3,'Ecust',True]
print(random.choice(a))

print(random.randrange(1,100,2)) # randrange ([start,] stop [,step])從指定範圍內,按指定基數遞增的集合中獲取一個隨機數

print(random.random()) # 隨機生成下一個實數,它在[0,1)範圍內。

random.seed(1) #改變隨機數生成器的種子seed。如果你不瞭解其原理,你不必特別去設定seed,Python會幫你選擇seed。

print(a)
random.shuffle(a)# 將序列的所有元素隨機排序
print(a)

print(random.uniform(2,5))# 隨機生成下一個實數,它在[x,y]範圍內
7
Ecust
83
0.37961522332372777
[1, 2, 3, 'Ecust', True]
[3, 'Ecust', True, 1, 2]
3.486305261275823
# 三角函式

import math

print(math.acos(0))#返回x的反餘弦弧度值。
print(math.asin(0))
print(math.atan(1))
print(math.atan2(1,1))#返回給定的 X 及 Y 座標值的反正切值。
print(math.cos(math.pi/2))#返回x的弧度的餘弦值。
print(math.sin(math.pi/6))
print(math.tan(math.pi/4))
print(math.hypot(3,4))#返回歐幾里德範數 sqrt(x*x + y*y)。
print(math.degrees(math.pi/2))#將弧度轉換為角度
print(math.radians(60))#將角度轉換為弧度
1.5707963267948966
0.0
0.7853981633974483
0.7853981633974483
6.123233995736766e-17
0.49999999999999994
0.9999999999999999
5.0
90.0
1.0471975511965976
# 數字常量
#math.pi,math.e

字串

# Python訪問字串中的值
Var1 = 'Xuhuan'
Var2 = 'ECUST'
print(Var1[0])
print(Var2[2:5])
X
UST
#字串更新
var = 'ECUST'
print(var + 'Xuhuan!')
ECUSTXuhuan
#轉義字元
#在需要在字元中使用特殊字元時,python用反斜槓(\)轉義字元。
'''
\(在行尾時)	續行符
\\	反斜槓符號
\'	單引號
\"	雙引號
\a	響鈴
\b	退格(Backspace)
\e	轉義
\000	空
\n	換行
\v	縱向製表符
\t	橫向製表符
\r	回車
\f	換頁
\oyy	八進位制數,yy代表的字元,例如:\o12代表換行
\xyy	十六進位制數,yy代表的字元,例如:\x0a代表換行
\other	其它的字元以普通格式輸出
'''
#字串運算子

print("Xuhuan" + "ECUST!")#字串連線

print("Xuhuan" * 2)#重複輸出字串

a = 'ECUST'
print(a[3])#通過索引獲取字串中字元
print(a[2:4])

if 's' in a:
    print('Yes-s')
elif 'S' in a:
    print('Yes-S')
else:
    print('No')
    
if 'u' not in a:
    print('No')
else:
    print('Yes')
    
print('xuhuan\n')
print(r'Xuhuan\n')#所有的字串都是直接按照字面的意思來使用,沒有轉義特殊或不能列印的字元。
XuhuanECUST!
XuhuanXuhuan
S
US
Yes-S
No
xuhuan

Xuhuan\n
#字串格式化

print('I am %s , I have %d flowers'%('Xuhuan',20))

'''
      %c	 格式化字元及其ASCII碼
      %s	 格式化字串
      %d	 格式化整數
      %u	 格式化無符號整型
      %o	 格式化無符號八進位制數
      %x	 格式化無符號十六進位制數
      %X	 格式化無符號十六進位制數(大寫)
      %f	 格式化浮點數字,可指定小數點後的精度
      %e	 用科學計數法格式化浮點數
      %E	 作用同%e,用科學計數法格式化浮點數
      %g	 %f和%e的簡寫
      %G	 %f 和 %E 的簡寫
      %p	 用十六進位制數格式化變數的地址
'''
I am Xuhuan , I have 20 flowers
#格式化操作符

'''
*	定義寬度或者小數點精度
-	用做左對齊
+	在正數前面顯示加號( + )
<sp>	在正數前面顯示空格
#	在八進位制數前面顯示零('0'),在十六進位制前面顯示'0x'或者'0X'(取決於用的是'x'還是'X')
0	顯示的數字前面填充'0'而不是預設的空格
%	'%%'輸出一個單一的'%'
(var)	對映變數(字典引數)
m.n.	m 是顯示的最小總寬度,n 是小數點後的位數(如果可用的話)
'''
#三引號
#python三引號允許一個字串跨多行,字串中可以包含換行符、製表符以及其他特殊字元。

para_str = '''這是一個多行字串的例項
多行字串可以使用製表符
TAB ( \t )。
也可以使用換行符 [ \n ]。
'''

print(para_str)
這是一個多行字串的例項
多行字串可以使用製表符
TAB ( 	 )。
也可以使用換行符 [ 
 ]。
#unicode字串
#在字串前面加上字首u

s = u'XuHuan'
print(s)
XuHuan
#Python 字串自建函式

'''
1	capitalize()
將字串的第一個字元轉換為大寫

2	center(width, fillchar)
返回一個指定的寬度 width 居中的字串,fillchar 為填充的字元,預設為空格。

3	count(str, beg= 0,end=len(string))
返回 str 在 string 裡面出現的次數,如果 beg 或者 end 指定則返回指定範圍內 str 出現的次數

4	bytes.decode(encoding="utf-8", errors="strict")
Python3 中沒有 decode 方法,但我們可以使用 bytes 物件的 decode() 方法來解碼給定的 bytes 物件,這個 bytes 物件可以由 str.encode() 來編碼返回。

5	encode(encoding='UTF-8',errors='strict')
以 encoding 指定的編碼格式編碼字串,如果出錯預設報一個ValueError 的異常,除非 errors 指定的是'ignore'或者'replace'

6	endswith(suffix, beg=0, end=len(string))
檢查字串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的範圍內是否以 obj 結束,如果是,返回 True,否則返回 False.

7	expandtabs(tabsize=8)
把字串 string 中的 tab 符號轉為空格,tab 符號預設的空格數是 8 。

8	find(str, beg=0 end=len(string))
檢測 str 是否包含在字串中,如果指定範圍 beg 和 end ,則檢查是否包含在指定範圍內,如果包含返回開始的索引值,否則返回-1

9	index(str, beg=0, end=len(string))
跟find()方法一樣,只不過如果str不在字串中會報一個異常.

10	isalnum()
如果字串至少有一個字元並且所有字元都是字母或數字則返 回 True,否則返回 False

11	isalpha()
如果字串至少有一個字元並且所有字元都是字母則返回 True, 否則返回 False

12	isdigit()
如果字串只包含數字則返回 True 否則返回 False..

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

14	isnumeric()
如果字串中只包含數字字元,則返回 True,否則返回 False

15	isspace()
如果字串中只包含空白,則返回 True,否則返回 False.

16	istitle()
如果字串是標題化的(見 title())則返回 True,否則返回 False

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

18	join(seq)
以指定字串作為分隔符,將 seq 中所有的元素(的字串表示)合併為一個新的字串

19	len(string)
返回字串長度

20	ljust(width[, fillchar])
返回一個原字串左對齊,並使用 fillchar 填充至長度 width 的新字串,fillchar 預設為空格。

21	lower()
轉換字串中所有大寫字元為小寫.

22	lstrip()
截掉字串左邊的空格或指定字元。

23	maketrans()
建立字元對映的轉換表,對於接受兩個引數的最簡單的呼叫方式,第一個引數是字串,表示需要轉換的字元,第二個引數也是字串表示轉換的目標。

24	max(str)
返回字串 str 中最大的字母。

25	min(str)
返回字串 str 中最小的字母。

26	replace(old, new [, max])
把 將字串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次。

27	rfind(str, beg=0,end=len(string))
類似於 find()函式,不過是從右邊開始查詢.

28	rindex( str, beg=0, end=len(string))
類似於 index(),不過是從右邊開始.

29	rjust(width,[, fillchar])
返回一個原字串右對齊,並使用fillchar(預設空格)填充至長度 width 的新字串

30	rstrip()
刪除字串字串末尾的空格.

31	split(str="", num=string.count(str))
num=string.count(str)) 以 str 為分隔符擷取字串,如果 num 有指定值,則僅擷取 num 個子字串

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

33	startswith(str, beg=0,end=len(string))
檢查字串是否是以 obj 開頭,是則返回 True,否則返回 False。如果beg 和 end 指定值,則在指定範圍內檢查。

34	strip([chars])
在字串上執行 lstrip()和 rstrip()

35	swapcase()
將字串中大寫轉換為小寫,小寫轉換為大寫

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

37	translate(table, deletechars="")
根據 str 給出的表(包含 256 個字元)轉換 string 的字元, 要過濾掉的字元放到 deletechars 引數中

38	upper()
轉換字串中的小寫字母為大寫

39	zfill (width)
返回長度為 width 的字串,原字串右對齊,前面填充0

40	isdecimal()
檢查字串是否只包含十進位制字元,如果是返回 true,否則返回 false。
'''


'\n1\tcapitalize()\n將字串的第一個字元轉換為大寫\n\n2\tcenter(width, fillchar)\n返回一個指定的寬度 width 居中的字串,fillchar 為填充的字元,預設為空格。\n\n3\tcount(str, beg= 0,end=len(string))\n返回 str 在 string 裡面出現的次數,如果 beg 或者 end 指定則返回指定範圍內 str 出現的次數\n\n4\tbytes.decode(encoding="utf-8", errors="strict")\nPython3 中沒有 decode 方法,但我們可以使用 bytes 物件的 decode() 方法來解碼給定的 bytes 物件,這個 bytes 物件可以由 str.encode() 來編碼返回。\n\n5\tencode(encoding=\'UTF-8\',errors=\'strict\')\n以 encoding 指定的編碼格式編碼字串,如果出錯預設報一個ValueError 的異常,除非 errors 指定的是\'ignore\'或者\'replace\'\n\n6\tendswith(suffix, beg=0, end=len(string))\n檢查字串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的範圍內是否以 obj 結束,如果是,返回 True,否則返回 False.\n\n7\texpandtabs(tabsize=8)\n把字串 string 中的 tab 符號轉為空格,tab 符號預設的空格數是 8 。\n\n8\tfind(str, beg=0 end=len(string))\n檢測 str 是否包含在字串中,如果指定範圍 beg 和 end ,則檢查是否包含在指定範圍內,如果包含返回開始的索引值,否則返回-1\n\n9\tindex(str, beg=0, end=len(string))\n跟find()方法一樣,只不過如果str不在字串中會報一個異常.\n\n10\tisalnum()\n如果字串至少有一個字元並且所有字元都是字母或數字則返 回 True,否則返回 False\n\n11\tisalpha()\n如果字串至少有一個字元並且所有字元都是字母則返回 True, 否則返回 False\n\n12\tisdigit()\n如果字串只包含數字則返回 True 否則返回 False..\n\n13\tislower()\n如果字串中包含至少一個區分大小寫的字元,並且所有這些(區分大小寫的)字元都是小寫,則返回 True,否則返回 False\n\n14\tisnumeric()\n如果字串中只包含數字字元,則返回 True,否則返回 False\n\n15\tisspace()\n如果字串中只包含空白,則返回 True,否則返回 False.\n\n16\tistitle()\n如果字串是標題化的(見 title())則返回 True,否則返回 False\n\n17\tisupper()\n如果字串中包含至少一個區分大小寫的字元,並且所有這些(區分大小寫的)字元都是大寫,則返回 True,否則返回 False\n\n18\tjoin(seq)\n以指定字串作為分隔符,將 seq 中所有的元素(的字串表示)合併為一個新的字串\n\n19\tlen(string)\n返回字串長度\n\n20\tljust(width[, fillchar])\n返回一個原字串左對齊,並使用 fillchar 填充至長度 width 的新字串,fillchar 預設為空格。\n\n21\tlower()\n轉換字串中所有大寫字元為小寫.\n\n22\tlstrip()\n截掉字串左邊的空格或指定字元。\n\n23\tmaketrans()\n建立字元對映的轉換表,對於接受兩個引數的最簡單的呼叫方式,第一個引數是字串,表示需要轉換的字元,第二個引數也是字串表示轉換的目標。\n\n24\tmax(str)\n返回字串 str 中最大的字母。\n\n25\tmin(str)\n返回字串 str 中最小的字母。\n\n26\treplace(old, new [, max])\n把 將字串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次。\n\n27\trfind(str, beg=0,end=len(string))\n類似於 find()函式,不過是從右邊開始查詢.\n\n28\trindex( str, beg=0, end=len(string))\n類似於 index(),不過是從右邊開始.\n\n29\trjust(width,[, fillchar])\n返回一個原字串右對齊,並使用fillchar(預設空格)填充至長度 width 的新字串\n\n30\trstrip()\n刪除字串字串末尾的空格.\n\n31\tsplit(str="", num=string.count(str))\nnum=string.count(str)) 以 str 為分隔符擷取字串,如果 num 有指定值,則僅擷取 num 個子字串\n\n32\tsplitlines([keepends])\n按照行(\'\r\', \'\r\n\', \n\')分隔,返回一個包含各行作為元素的列表,如果引數 keepends 為 False,不包含換行符,如果為 True,則保留換行符。\n\n33\tstartswith(str, beg=0,end=len(string))\n檢查字串是否是以 obj 開頭,是則返回 True,否則返回 False。如果beg 和 end 指定值,則在指定範圍內檢查。\n\n34\tstrip([chars])\n在字串上執行 lstrip()和 rstrip()\n\n35\tswapcase()\n將字串中大寫轉換為小寫,小寫轉換為大寫\n\n36\ttitle()\n返回"標題化"的字串,就是說所有單詞都是以大寫開始,其餘字母均為小寫(見 istitle())\n\n37\ttranslate(table, deletechars="")\n根據 str 給出的表(包含 256 個字元)轉換 string 的字元, 要過濾掉的字元放到 deletechars 引數中\n\n38\tupper()\n轉換字串中的小寫字母為大寫\n\n39\tzfill (width)\n返回長度為 width 的字串,原字串右對齊,前面填充0\n\n40\tisdecimal()\n檢查字串是否只包含十進位制字元,如果是返回 true,否則返回 false。\n'

列表

序列是Python中最基本的資料結構。序列中的每個元素都分配一個數字 - 它的位置,或索引,第一個索引是0,第二個索引是1,依此類推。

Python有6個序列的內建型別,但最常見的是列表和元組。

序列都可以進行的操作包括索引,切片,加,乘,檢查成員。

此外,Python已經內建確定序列的長度以及確定最大和最小的元素的方法。

列表是最常用的Python資料型別,它可以作為一個方括號內的逗號分隔值出現。

列表的資料項不需要具有相同的型別

# 訪問列表中的值
list1 = ['China','USA',True,123]
list2 = [1,2,3,4,5,6,7]

print(list1[0])
print(list2[1:5])
China
[2, 3, 4, 5]
#更新列表
list = ['China','USA',True,123]
print(list[2])
list[2] = 'JAPAN'
print(list[2])

#刪除列表
list = ['China','USA',True,123]
print(list)
del list[2]
print(list)
True
JAPAN
['China', 'USA', True, 123]
['China', 'USA', 123]
#列表指令碼操作符

list = ['China','USA',True,123]

print(len(list))#列表長度

print(list+[1,2,3])#列表組合

print(list*2)#列表重複

if 'USA' in list:
    print('YES')
    
for i in list:
    print(i,end = ' ')
4
['China', 'USA', True, 123, 1, 2, 3]
['China', 'USA', True, 123, 'China', 'USA', True, 123]
YES
China USA True 123 
# 列表擷取與拼接

l = [23,55,66]
print(l[1],l[-1],l[1:])

list = ['China','USA',True,123]
l += list
print(l)
55 66 [55, 66]
[23, 55, 66, 'China', 'USA', True, 123]
# 巢狀列表

s = [7,9,6]
t = [1,2,s]
list = ['China','USA',[5,4,3],True,123,t]

print(list)
print(list[2])
print(list[2][2])
print(list[5][1:])
['China', 'USA', [5, 4, 3], True, 123, [1, 2, [7, 9, 6]]]
[5, 4, 3]
3
[2, [7, 9, 6]]
# 列表函式&方法

li = ['China','USA',True,123]
l = [1,2,3,4]
str = 'ECUST'
l1 = (1,2,3,4)


print(len(li))
print(max(l))
print(min(l))
print(list(str))
print(list(l1))#list()方法可將元祖轉換為列表
4
4
1
['E', 'C', 'U', 'S', 'T']
[1, 2, 3, 4]
l = ['China','USA','Elephant',123]

l.append('USA')#在列表末尾新增新的物件
print(l)

print(l.count('USA'))#統計元素在列表中出現的次數

l.extend(['JAPAN','ECUST'])#在列表末尾一次性追加另一個序列的多個值
print(l)

print(l.index('USA'))#在列表中找到某個值第一個匹配項的索引位置

l.insert(2,'Canada')#將物件插入列表
print(l)

l.pop()#移除列表中最後一個元素
print(l)
l.pop(2)#移除列表中指定位置的元素
print(l)

l.remove(123)#移除列表中某個值的第一個匹配項
print(l)

l.reverse()#反向列表中元素
print(l)

l.sort()#對原列表進行排序
print(l)

l2 = l.copy()#複製列表
print(l2)

l2.clear()
print(l2)
['China', 'USA', 'Elephant', 123, 'USA']
2
['China', 'USA', 'Elephant', 123, 'USA', 'JAPAN', 'ECUST']
1
['China', 'USA', 'Canada', 'Elephant', 123, 'USA', 'JAPAN', 'ECUST']
['China', 'USA', 'Canada', 'Elephant', 123, 'USA', 'JAPAN']
['China', 'USA', 'Elephant', 123, 'USA', 'JAPAN']
['China', 'USA', 'Elephant', 'USA', 'JAPAN']
['JAPAN', 'USA', 'Elephant', 'USA', 'China']
['China', 'Elephant', 'JAPAN', 'USA', 'USA']
['China', 'Elephant', 'JAPAN', 'USA', 'USA']
[]

元祖

Python 的元組與列表類似,不同之處在於元組的元素不能修改。

元組使用小括號,列表使用方括號。

元組建立很簡單,只需要在括號中新增元素,並使用逗號隔開即可。

tup1 = ()#建立空元祖
print(tup1)

#元組中只包含一個元素時,需要在元素後面新增逗號,否則括號會被當作運算子使用
tup2 = (50)
print(type(tup2))
tup2 = (50,)
print(type(tup2))

#訪問元祖
tup = ('China', 'Elephant', 'JAPAN', 'USA', 'USA')
print(tup[2])
print(tup[1:4])

#元祖中的元素是不允許修改的,但我們可以對元祖進行組合
tup1 = ('China', 'Elephant', 'JAPAN', 'USA', 'USA')
tup2 = (1,2,3,4,5,6,7)
tup3 = tup1 + tup2
print(tup3)

#元祖中的元素是不允許刪除的,但我們可以使用del語句來刪除整個元祖
tup = ('China', 'Elephant', 'JAPAN', 'USA', 'USA')
print(tup)
del tup
print(tup)
()
<class 'int'>
<class 'tuple'>
JAPAN
('Elephant', 'JAPAN', 'USA')
('China', 'Elephant', 'JAPAN', 'USA', 'USA', 1, 2, 3, 4, 5, 6, 7)
('China', 'Elephant', 'JAPAN', 'USA', 'USA')



---------------------------------------------------------------------------

NameError                                 Traceback (most recent call last)

<ipython-input-106-d315be1523c0> in <module>()
     23 print(tup)
     24 del tup
---> 25 print(tup)


NameError: name 'tup' is not defined
#元祖運算子

tup = ('China', 'Elephant', 'JAPAN'