Python 是一種高層次的結合了解釋性、編譯性、互動性和面向對象的腳本語言。Python 由 Guido van Rossum 於 1989 年底在荷蘭國家數學和計算機科學研究所發明,第一個公開發行版發行於 1991 年。
易於學習:Python 有相對較少的關鍵字,結構簡單,和一個明確定義的語法,學習起來更加簡單。
易於閱讀:Python 代碼定義的更清晰。
易於維護:Python 的成功在於它的原始碼是相當容易維護的。
一個廣泛的標準庫:Python 的最大的優勢之一是豐富的庫,跨平臺的,在 UNIX,Windows 和 macOS 兼容很好。
互動模式:互動模式的支持,您可以從終端輸入執行代碼並獲得結果的語言,互動的測試和調試代碼片斷。
可移植:基於其開放原始碼的特性,Python 已經被移植(也就是使其工作)到許多平臺。
可擴展:如果你需要一段運行很快的關鍵代碼,或者是想要編寫一些不願開放的算法,你可以使用 C 或 C++ 完成那部分程序,然後從你的 Python 程序中調用。
資料庫:Python 提供所有主要的商業資料庫的接口。
GUI 編程:Python 支持 GUI 可以創建和移植到許多系統調用。
可嵌入:你可以將 Python 嵌入到 C/C++ 程序,讓你的程序的用戶獲得"腳本化"的能力。
面向對象:Python 是強面向對象的語言,程序中任何內容統稱為對象,包括數字、字符串、函數等。
運行 Python交互式解釋器在命令行窗口執行python後,進入 Python 的交互式解釋器。exit() 或 Ctrl + D 組合鍵退出交互式解釋器。
命令行腳本在命令行窗口執行python script-file.py,以執行 Python 腳本文件。
指定解釋器如果在 Python 腳本文件首行輸入#!/usr/bin/env python,那麼可以在命令行窗口中執行/path/to/script-file.py以執行該腳本文件。
註:該方法不支持 Windows 環境。
編碼默認情況下,3.x 源碼文件都是 UTF-8 編碼,字符串都是 Unicode 字符。也可以手動指定文件編碼:
或者
注意: 該行標註必須位於文件第一行
標識符第一個字符必須是英文字母或下劃線 _ 。
標識符的其他的部分由字母、數字和下劃線組成。
標識符對大小寫敏感。
註:從 3.x 開始,非 ASCII 標識符也是允許的,但不建議。
保留字保留字即關鍵字,我們不能把它們用作任何標識符名稱。Python 的標準庫提供了一個 keyword 模塊,可以輸出當前版本的所有關鍵字:
>>> import keyword
>>> keyword.kwlist
['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
(左右滑動可查看完整代碼)
注釋單行注釋採用#,多行注釋採用'''或"""。
# 這是單行注釋
'''
這是多行注釋
這是多行注釋
'''
"""
這也是多行注釋
這也是多行注釋
"""
Python 最具特色的就是使用縮進來表示代碼塊,不需要使用大括號 {}。
縮進的空格數是可變的,但是同一個代碼塊的語句必須包含相同的縮進空格數。縮進不一致,會導致運行錯誤。
Python 通常是一行寫完一條語句,但如果語句很長,我們可以使用反斜槓\來實現多行語句。
total = item_one + \
item_two + \
item_three
在 [], {}, 或 () 中的多行語句,不需要使用反斜槓\。
空行函數之間或類的方法之間用空行分隔,表示一段新的代碼的開始。類和函數入口之間也用一行空行分隔,以突出函數入口的開始。
空行與代碼縮進不同,空行並不是 Python 語法的一部分。書寫時不插入空行,Python 解釋器運行也不會出錯。但是空行的作用在於分隔兩段不同功能或含義的代碼,便於日後代碼的維護或重構。
記住:空行也是程序代碼的一部分。
等待用戶輸入input函數可以實現等待並接收命令行中的用戶輸入。
content = input("\n\n請輸入點東西並按 Enter 鍵\n")
print(content)
Python 可以在同一行中使用多條語句,語句之間使用分號;分割。
import sys; x = 'hello world'; sys.stdout.write(x + '\n')
縮進相同的一組語句構成一個代碼塊,我們稱之代碼組。
像if、while、def和class這樣的複合語句,首行以關鍵字開始,以冒號:結束,該行之後的一行或多行代碼構成代碼組。
我們將首行及後面的代碼組稱為一個子句(clause)。
print 輸出print 默認輸出是換行的,如果要實現不換行需要在變量末尾加上end=""或別的非換行符字符串:
print('123') # 默認換行
print('123', end = "") # 不換行
在 Python 用 import 或者 from...import 來導入相應的模塊。
將整個模塊導入,格式為:import module_name
從某個模塊中導入某個函數,格式為:from module_name import func1
從某個模塊中導入多個函數,格式為:from module_name import func1, func2, func3
將某個模塊中的全部函數導入,格式為:from module_name import *
運算符算術運算符比較運算符
賦值運算符
位運算符
邏輯運算符
具有相同優先級的運算符將從左至右的方式依次進行。用小括號()可以改變運算順序。
變量變量在使用前必須先"定義"(即賦予變量一個值),否則會報錯:
>>> name
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'name' is not defined
只有 True 和 False 兩個值,表示真或假。
數字(number)整型(int)整數值,可正數亦可複數,無小數。
3.x 整型是沒有限制大小的,可以當作 Long 類型使用,所以 3.x 沒有 2.x 的 Long 類型。
浮點型由整數部分與小數部分組成,浮點型也可以使用科學計數法表示(2.5e2 = 2.5 x 10^2 = 250)
複數(complex)複數由實數部分和虛數部分構成,可以用a + bj,或者complex(a,b)表示,複數的實部 a 和虛部 b 都是浮點型。
數字運算不同類型的數字混合運算時會將整數轉換為浮點數
在不同的機器上浮點運算的結果可能會不一樣
在整數除法中,除法 / 總是返回一個浮點數,如果只想得到整數的結果,丟棄可能的分數部分,可以使用運算符 //。
// 得到的並不一定是整數類型的數,它與分母分子的數據類型有關係
在交互模式中,最後被輸出的表達式結果被賦值給變量 _,_ 是個只讀變量
數學函數註:以下函數的使用,需先導入 math 包。
隨機數函數註:以下函數的使用,需先導入 random 包。
三角函數註:以下函數的使用,需先導入 math 包。
數學常量字符串(string)
單引號和雙引號使用完全相同
使用三引號('''或""")可以指定一個多行字符串
轉義符(反斜槓\)可以用來轉義,使用r可以讓反斜槓不發生轉義,如r"this is a line with \n",則\n會顯示,並不是換行
按字面意義級聯字符串,如"this " "is " "string"會被自動轉換為this is string
字符串可以用 + 運算符連接在一起,用 * 運算符重複
字符串有兩種索引方式,從左往右以 0 開始,從右往左以 -1 開始
字符串不能改變
沒有單獨的字符類型,一個字符就是長度為 1 的字符串
字符串的截取的語法格式如下:變量[頭下標:尾下標]
轉義字符字符串運算符字符串格式化在 Python 中,字符串格式化不是 sprintf 函數,而是用 % 符號。例如:
print("我叫%s, 今年 %d 歲!" % ('小明', 10))
// 輸出:
我叫小明, 今年 10 歲!
格式化符號:
輔助指令:
Python 2.6 開始,新增了一種格式化字符串的函數 str.format(),它增強了字符串格式化的功能。
多行字符串實例:
string = '''
print(\tmath.fabs(-10))
print(\nrandom.choice(li))
'''
print(string)
輸出:
print( math.fabs(-10))
print(
random.choice(li))
Unicode
在 2.x 中,普通字符串是以 8 位 ASCII 碼進行存儲的,而 Unicode 字符串則存儲為 16 位 Unicode 字符串,這樣能夠表示更多的字符集。使用的語法是在字符串前面加上前綴 u。
在 3.x 中,所有的字符串都是 Unicode 字符串。
字符串函數字節(bytes)在 3.x 中,字符串和二進位數據完全區分開。文本總是 Unicode,由 str 類型表示,二進位數據則由 bytes 類型表示。Python 3 不會以任意隱式的方式混用 str 和 bytes,你不能拼接字符串和字節流,也無法在字節流裡搜索字符串(反之亦然),也不能將字符串傳入參數為字節流的函數(反之亦然)。
bytes 類型與 str 類型,二者的方法僅有 encode() 和 decode() 不同。
bytes 類型數據需在常規的 str 類型前加個 b 以示區分,例如 b'abc'。
只有在需要將 str 編碼(encode)成 bytes 的時候,比如:通過網絡傳輸數據;或者需要將 bytes 解碼(decode)成 str 的時候,我們才會關注 str 和 bytes 的區別。
bytes 轉 str:
b'abc'.decode()
str(b'abc')
str(b'abc', encoding='utf-8')
str 轉 bytes:
'中國'.encode()
bytes('中國', encoding='utf-8'
來源:https://www.cnblogs.com/shockerli/p/python-study-note.html