Python 中的變量不須要聲明。每一個變量在使用前都必須賦值,變量賦值之後該變量纔會被建立。python
在Python中,變量就是變量,它沒有類型,咱們所說的「類型」是變量所指的內存中對象的類型。算法
等號(=)用來給變量賦值。數據結構
等號(=)運算符左邊是一個變量名,等號(=)運算符右邊是存儲在變量中的值。例如:app
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero counter = 100 # 整型變量 miles = 1000.0 # 浮點型變量 name = "Zero" # 字符串 print(counter) print(miles) print(name)
執行以上程序會輸出以下結果:ide
C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py 100 1000.0 Zero Process finished with exit code 0
多個變量賦值函數
Python 容許你同時爲多個變量賦值。例如:工具
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero a = b = c = 1
以上實例,建立一個整型對象,值爲1,三個變量被分配到相同的內存空間桑。測試
你也能夠爲多個對象指定多個變量。例如:spa
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero a,b,c = 1,2,"Zero"
以上實例,兩個整型對象 1 和 2 分配給變量 a 和 b ,字符串對象 "Zero" 分配給變量 c 。命令行
標準數據類型
Python 3 中有六個標準的數據類型:
Number (數字)
Python 3 支持 int、float、bool、complex(複數)。
在Python 3 裏 , 只有一種整數類型 int ,表示爲長整型,沒有Python 2 中的long。
像大多數語言同樣,數值類型的賦值和計算都是很直觀的。
內置的 type() 函數能夠用來查詢變量所指的對象類型。
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero 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 來判斷:
C:\Users\Administrator>python Python 3.6.3 (v3.6.3:2c5fed8, Oct 3 2017, 18:11:49) [MSC v.1900 64 bit (AMD64 on win32 Type "help", "copyright", "credits" or "license" for more information. >>> a = 111 >>> isinstance(a,int) True >>>
isinstance 和 type 的區別在於:
class A: pass class B(A): pass isinstance(A(),A) # returns True type(A()) == A # returns True isinstance(B(),A) # returns True type(B()) == A # returns False
區別就是:
注意:在Python 2 中是沒有布爾型的,它用數值 0 表示 False ,用 1 表示 True 。到 Python 3 中,把 True 和 False 定義成關鍵字了,但它們的值仍是 1 和 0 ,它們能夠和數字相加。 |
當你指定一個值時,Number 對象就會被建立:
var1 = 1
var2 = 10
你也可使用 del 語句刪除一些對象引用。
del 語句的語法是:
del var1[,var2[,var3[....,varN]]]
你能夠經過使用 del 語句刪除單個或多個對象。例如:
del var del var_a,var_b
數值運算
>>>5 + 4 # 加法 9 >>> 4.3 - 2 # 減法 2.3 >>> 3 * 7 # 乘法 21 >>> 2 / 4 # 除法,獲得一個浮點數 0.5 >>> 2 // 4 # 除法,獲得一個整數 0 >>> 17 % 3 # 取餘 2 >>> 2 ** 5 # 乘方 32
注意:
數值類型實例
int | float | complex |
10 |
0.0 | 3.14j |
100 |
15.20 | 45.j |
-786 |
-21.9 | 9.322e-36j |
080 | 32.3+e18 |
.876j |
-0490 |
-90. | -.6545+0J |
-0x260 |
-32.54e100 | 3e+26J |
0x69 |
70.2E-12 | 4.53e-7j |
Python 還支持複數,複數由實數部分和虛數部分構成,能夠用 a+bj,或者 complex(a,b) 表示,複數的實部 a 和 虛部 b 都是浮點型
String (字符型)
Python 中的字符串用單引號(’)或雙引號(「)括起來,同時使用反斜槓(\)轉義特殊字符。
字符串的截取的語法格式以下:
變量[頭下標:尾下標]
索引值以 0 爲開始值, -1 爲從末尾的開始位置。
加號(+)是字符串的鏈接符,星號(*)表示複製當前字符串,緊跟的數值爲複製的次數。實例以下:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero str = "ZeroMr" print(str) # 輸出字符串 print(str[0:-1]) # 輸出第一個到倒數第二個的全部字符 print(str[0]) # 輸出字符串第一個字符 print(str[2:5]) # 輸出從第三個開始到第五個的字符 print(str[2:]) # 輸出從第三個開始後的全部字符 print(str * 2) # 輸出字符串兩次 print(str + "TEST") # 鏈接字符串
執行以上程序會輸出以下結果:
C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py
ZeroMr
ZeroM
Z
roM
roMr
ZeroMrZeroMr
ZeroMrTEST
Process finished with exit code 0
Python 是用反斜槓(\)轉義特殊字符,若是你不想讓反斜槓發生轉義,能夠在字符串的前面添加一個 r ,表示原始字符串:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero print("Ze\noMr") print(r"Ze\noMr") print("Ze\roMr") print(r"Ze\roMr") # 運行結果 C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py Ze oMr Ze\noMr oMr Ze\roMr Process finished with exit code 0
另外,反斜槓(\)能夠做爲續行符,表示下一行是上一行的延續。也可使用 """......""" 或者 '''......''' 跨越多行。
注意。Python 沒有單獨的字符類型,一個字符就是長度爲 1 的字符串。
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero word = "python" print(word[0],word[5]) # 輸出結果:p n print(word[-1],word[-6]) # 輸出結果:n p #輸出結果: C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py p n n p Process finished with exit code 0
與 C 的字符串不一樣的是,Python 字符串不能被改變,向一個索引位置賦值,好比 wor[0] = "m" 會致使錯誤。
注意:
List (列表)
List(列表)是 Python 中使用最頻繁的數據類型。
列表能夠完成大多數集合類的數據結構實現。列表中元素的類型能夠不相同,它支持數字,字符串甚至能夠包含列表(所謂嵌套)。
列表是寫在方括號」 [] 「之間、用逗號分隔開的元素列表。
和字符串同樣,列表一樣能夠被索引和截取,列表被截取後返回一個包含所需元素的新列表。
列表截取的語法格式以下:
變量[頭下標:尾下標]
索引值以 0 爲開始值, -1 爲從末尾的開始位置。
加號(+)是列表鏈接運算符,星號(*)是重複操做,以下實例:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero list = ['abcd',786,2.23,'Zero',70.2] tinylist = [123,'Zero'] print(list) # 輸出完整列表 print(list[0]) # 輸出列表第一個元素 print(list[1:3]) # 從第二個開始輸出到第三個元素 print(list[2:]) # 輸出從第三個元素開始的全部元素 print(tinylist * 2) # 輸出兩次列表 print(list + tinylist) # 鏈接列表
以上實例輸出結果:
C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py ['abcd', 786, 2.23, 'Zero', 70.2] abcd [786, 2.23] [2.23, 'Zero', 70.2] [123, 'Zero', 123, 'Zero'] ['abcd', 786, 2.23, 'Zero', 70.2, 123, 'Zero'] Process finished with exit code 0
與Python 字符串不同的是,列表中的元素時能夠改變的:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero a = [1,2,3,4,5,6] a[0] = 9 a[2:5] = [13,14,15] print(a) a[2:5] = [] # 將對應元素設置爲[] print(a)
C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py [9, 2, 13, 14, 15, 6] [9, 2, 6] Process finished with exit code 0
List 內置了不少方法,例如 append() 、pop() 等等
注意:
Tuple(元組)
元組(tuple)也列表相似,不一樣之處在於元組的元素不能修改,元組寫在小括號 」 () 「 裏,元素之間用逗號隔開。
元組中的元素類型也能夠不相同:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero tuple = ('abcd',786,2.23,'Zero',70.2) tinytuple = (123,'Zero') print(tuple) # 輸出完整元組 print(tuple[0]) # 輸出元組的第一個元素 print(tuple[1:3]) # 輸出從第二個元素開始到第三個元素 print(tuple[2:]) # 輸出從第三個元素開始的全部元素 print(tinytuple * 2) # 輸出兩次元組 print(tuple + tinytuple) # 鏈接元組 ''' 示例輸出結果: C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py ('abcd', 786, 2.23, 'Zero', 70.2) abcd (786, 2.23) (2.23, 'Zero', 70.2) (123, 'Zero', 123, 'Zero') ('abcd', 786, 2.23, 'Zero', 70.2, 123, 'Zero') Process finished with exit code 0 '''
元組與字符串相似,能夠被索引且下標索引從 0 開始, -1 爲從末尾開始的位置。也能夠進行截取(看上面,這裏再也不贅述)。
其實,能夠把字符串看做一種特殊的元組。
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero tup = (1,2,3,4,5,6) print(tup[0]) print(tup[1:5]) ''' 輸出: 1 (2, 3, 4, 5) ''' tup[0] = 11 # 修改元組元素的操做是非法的(這是錯誤的行爲) ''' 輸出錯誤提示: Traceback (most recent call last): File "C:/Users/Administrator/PycharmProjects/Zero/day1/1.py", line 12, in <module> tup[0] = 11 # 修改元組元素的操做是非法的(這是錯誤的行爲) TypeError: 'tuple' object does not support item assignment '''
雖然 tuple 的元素不可改變,但它能夠包含可變的對象,好比 list 列表。
構造包含 0 個或 1 個元素的元組比較特殊,因此有一些額外的語法規則:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero tu1 = () # 空元素 tup2 = (20,) # 一個元素,須要在元素後面添加逗號
string、list 和 tuple 都屬於sequence(序列)。
注意:
Set(集合)
集合(set)是一個無序不重複元素的序列。
基本功能是進行成員關係測試和刪除重複元素。
可使用大括號 {} 或者 set() 函數建立集合,注意:建立一個空集合必須用 set() 而不是 {} ,由於 {} 是用來建立一個空字典的。
建立格式:
parame = {value01,value02,.......}
或者
set(value)
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero student = {'Tom','Jim','Mary','Tom','Jack','Rose'} print(student) # 輸出集合,重複的元素被自動去掉,這是集合的特性之一(去重) # 成員測試 if('Rose' in student): print('Rose 在集合中') else: print('Rose 不在集合中') # set 能夠進行集合運算 a = set('abracadabra') b = set('alacazam') print(a) print(a - b) # a 和 b 的差集 print(a | b) # a 和 b 的並集 print(a & b) # a 和 b 的交集 print(a ^ b) # a 和 b 中不一樣時存在的元素(對稱差集) ''' 輸出結果: {'Jack', 'Mary', 'Rose', 'Tom', 'Jim'} Rose 在集合中 {'r', 'a', 'b', 'c', 'd'} {'b', 'd', 'r'} {'r', 'a', 'm', 'b', 'z', 'l', 'c', 'd'} {'c', 'a'} {'r', 'l', 'm', 'b', 'd', 'z'} '''
Dictionary(字典)
字典(dictionary)是 Python 中另外一個很是有用的內置數據類型。
列表是有序的對象結合,字典是無序的對象集合。二者之間的區別在於:字典當中的元素時經過鍵來存取的,而不是經過偏移存取。
字典是一種映射類型,字典用 {} 標識,它是一個無序的鍵(key):值(value) 對集合。
鍵(key) 必須使用不可變類型。
在同一個字典中,鍵(key) 必須是惟一的。
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero dict = {} dict['one'] = "1 - 菜鳥教程" dict[2] = "2 - 菜鳥工具" tinydict = {'name':'Zero','code':1,'site':'www.baidu.com'} print(dict['one']) # 輸出鍵爲’one‘的值 print(dict[2]) # 輸出鍵爲 2 的值 print(tinydict.keys()) # 輸出全部的鍵 print(tinydict.values()) # 輸出全部值 ''' 輸出的結果: 1 - 菜鳥教程 2 - 菜鳥工具 dict_keys(['name', 'code', 'site']) dict_values(['Zero', 1, 'www.baidu.com']) '''
構造函數 dict() 能夠直接從鍵值對序列中構建字典以下:
C:\Users\Administrator>python Python 3.6.3 (v3.6.3:2c5fed8, Oct 3 2017, 18:11:49) [MSC v.1900 64 bit on win32 Type "help", "copyright", "credits" or "license" for more information. >>> dict([('Zero', 1), ('Google', 2), ('Taobao', 3)]) {'Zero': 1, 'Google': 2, 'Taobao': 3} >>> {x: x**2 for x in (2, 4, 6)} {2: 4, 4: 16, 6: 36} >>> dict(Zero=1, Google=2, Taobao=3) {'Zero': 1, 'Google': 2, 'Taobao': 3} >>>
另外,字典類型也有一些內置的函數,例如 clear()、keys()、values() 等。
注意:
Python 數據類型轉換
有時候,咱們須要對數據內置的心裏進行轉換,數據類型的轉換,你只須要將數據類型做爲函數名便可。
如下幾個內置的函數能夠執行數據類型之間的轉換,這些函數返回一個新的對象,表示轉換的值。
函數 | 描述 |
int(x[,base]) | 將 x 轉換爲一個整數 |
float(x) | 將 x 轉換到一個浮點數 |
complex(real [,imag]) | 建立一個複數 |
str(x) | 將對象 x 轉換位字符串 |
repr(x) | 將對象 x 轉換位表達式字符串 |
eval(str) | 用來計算在字符串中的有效 Python 表達式,並返回一個對象 |
tuple(s) | 將序列 s 轉換爲一個元組 |
list(s) | 將序列 s 轉換爲一個列表 |
set(s) | 轉換爲可變集合 |
dict(d) | 建立一個字典。d 必須是一個序列 (key,value) 元組 |
frozenset(s) | 轉換爲不可變集合 |
chr(x) | 將一個整數轉換爲一個字符 |
unichr(x) | 將一個整數轉換爲 Unicod 字符 |
ord(x) | 將一個字符轉換爲它的整數值 |
hex(x) | 將一個整數轉換爲一個十六進制字符串 |
oct(x) | 將一個整數轉換爲一個八進制字符串 |
元組 (小拓展)
通常來講,函數的返回值通常爲一個。
而函數返回多個值的時候,是以元組的方式返回的。
示例(命令行以下):
>>> def example(a,b): ... return (a,b) ... >>> type(example(3,4)) <class 'tuple'> >>>
Python 中的函數還能夠接收可變長參數,好比以 「*」 開頭的參數名,會將全部的參數收集到一個元組上。
例如:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero def test(*args): print(args) return args print(type(test(1,2,3,4))) # 能夠看見其函數的返回值是一個元組 ''' 輸出: (1, 2, 3, 4) <class 'tuple'> '''
字典(小拓展)
Python 中的字典是使用了一個稱爲散列表(hashtable)的算法(不具體展開)。
其特色是:無論字典中有多少項,in操做符花費的時間都差很少。
若是把一個字典對象做爲 for 的迭代對象,那麼這個操做將會遍歷字典的鍵:
#!/usr/bin/env python #-*-coding:utf-8 -*- # Author:Zero def example(d): # d 是一個字典對象 for c in d: print(c) # 若是調用函數試試的話,會發現函數會將 d 的全部鍵打印出來; # 也就是遍歷的是 d 的鍵,而不是值。 ''' 也能夠寫成: for c in dict: print(c,':',dict[c]) 或者: for c in dict: print(c,end=':'); print(dict[c]) 發現print()函數其實能夠添加多個參數,用逗號隔開. 使用方式: for c in dict: print(c+':'); print(dict[c]) 打印 key:value 結果發現其實 key 不必定時 string 類型,全部用 + 號會出現問題. 在list的使用中,開始時很容易忽視的一點是: list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ] print (list[1:3]) # 從第二個開始輸出到第三個元素 list[1:3] 其實輸出的只有兩個變量,即list中第二個元素到第三個元素,並非第1 第2 第3三個元素,並且要注意的是 print (list[2]) print (list[2:3]) 這兩句話打印的內容實際上是同樣的, 2.23 [2.23] 可是第二句話有中括號 python 與 C 語言和 Java 語言的一點不一樣,表如今它的變量不須要聲明變量類型,這是由於像 C 語言和 Java 語言來講,它們是靜態的,而 python 是動態的,變量的類型由賦予它的值來決定,例如: >>> a = 1 >>> a = 1.001 >>> a = "python" >>> print(a) python >>> 第一次爲變量 a 賦值爲整型,第二次賦值是浮點數,第三次是一個字符串,最後輸出時只保留了最後一次的賦值。 type 是用於求一個未知數據類型對象,而 isinstance 是用於判斷一個對象是不是已知類型。 type 不認爲子類是父類的一種類型,而isinstance會認爲子類是父類的一種類型。 能夠用 isinstance 判斷子類對象是否繼承於父類,type 不行。 綜合以上幾點,type 與 isinstance 雖然都與數據類型相關,但二者其實用法不一樣,type 主要用於判斷未知數據類型,isinstance 主要用於判斷 A 類是否繼承於 B 類: # 判斷子類對象是否繼承於父類 class father(object): pass class son(father): pass if __name__ == '__main__': print (type(son())==father) print (isinstance(son(),father)) print (type(son())) print (type(son)) 運行結果: False True <class '__main__.son'> <type 'type'> '''