前言
大家好,這裡是首發於「痴海」公眾號的從零開始學習 Python 系列教程。學習一門語言最好的辦法,就是教懂別人。在這公眾號,我會從 Python 最基礎的教程寫起,慢慢一步步進階。寫這教程同時也是我自己對於 Python 知識的複習鞏固。喜歡的朋友可以點選關注,一到週五每天更新 Python 相關知識,週六週日則會寫關於認識一些的文章。話不多說,開始今天的知識。
Python3 基礎語法
編碼
預設情況下,Pyhton3 原始碼檔案以 UTF-8 編碼,所有字串都是 unicode 字串。UTF-8 編碼相比大家都經常接觸,但 UTF-8 到底是什麼?卻很少有人去思考,只是懂的在程式設計中想要不出現中文亂碼,就需要使用 UTF-8 編碼格式。
UTF-8(8-bit Unicode Transformation Format)是一種針對 Unicode 的可變長度字元編碼,也是一種字首碼。它可以用來表示 Unicode 標準中的任何字元,且其編碼中的第一個位元組仍與 ASCII 相容,這使得原來處理 ASCII 字元的軟體無須或只須做少部分修改,即可繼續使用。因此,它逐漸成為電子郵件、網頁及其他儲存或傳送文字的應用中,優先採用的編碼。
1992 年初,為建立良好的位元組串編碼系統以供多位元組字符集使用,開始了一個正式的研究。ISO/IEC 10646的初稿中有一個非必須的附錄,名為 UTF。當中包含了一個供 32 位元的字元使用的位元組串編碼系統。這個編碼方式的效能並不令人滿意,但它提出了將 0-127 的範圍保留給 ASCII 以相容舊系統的概念。
發展到 1996 年起,微軟的 CAB(MS Cabinet)規格在 UTF-8 標準正式落實前就明確容許在任何地方使用 UTF-8 編碼系統。但有關的編碼器實際上從來沒有實現這方面的規格。
識別符號
識別符號(英文對應詞:identifier,縮寫為 ID ),又稱為識別碼,是一個用來識別物件的名稱,識別物件可能是概念、具體可數的物體或是不可數的物質。識別符號可能是字、編號、字母、符號,也可能是由上述元素所組成。
而在 Python 中識別符號的使用需要遵守一些規則:
- 第一個字元必須是字母表中字母或下劃線_。
- 識別符號的其他的部分由字母、數字和下劃線組成。
- 識別符號對大小寫敏感。
在 Python 3 中,非 ASCII 識別符號也是允許的了。
python 保留字
保留字即關鍵字,我們不能把它們用作任何識別符號名稱。Python 的標準庫提供了一個 keyword 模板,可以輸出當前版本的所有關鍵字:
>>> import keyword>>> keword.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 中單行以 # 開頭
#!/usr/bin/python3# 第一個註釋print("Hello, Python!") # 第二個註釋
複製程式碼
多行註釋可以用多個 # 號還有 ''' 和 """:
#!/usr/bin/python3# 第一個註釋# 第二個註釋'''第三註釋第四註釋'''"""第五註釋第六註釋"""print ("Hello, Python!")
複製程式碼
行與縮排
python 最具特色的就是使用縮排來表示程式碼塊,不需要使用大括號 {}。
縮排的空格數是可變的,但是同一個程式碼塊的語句必須包含相同的縮排空格數。例項如下:
if True: print ("True")else: print ("False")
複製程式碼
以下程式碼最後一行語句縮排數的空格數不一致,會導致執行錯誤:
if True: print ("Answer") print ("True")else: print ("Answer") print ("False") # 縮排不一致,會導致執行錯誤
複製程式碼
以上程式由於縮排不一致,執行後會出現類似以下錯誤:
File "test.py", line 6 print ("False") # 縮排不一致,會導致執行錯誤 ^IndentationError: unindent does not match any outer indentation level
複製程式碼
多行語句
Python 通常是一行寫完一條語句,但如果語句很長,我們可以使用反斜槓(\)來實現多行語句。
total = item_one + \ item_two + \ item_three
複製程式碼
在 []、{}、或()中的多行語句,不需要使用反斜槓(\)。
total = ['item_one', 'item_two', 'item_three', 'item_four', 'item_five']
複製程式碼
數字(Number)型別
python 中數字有四種型別:整數、長整數、浮點數和複數。
- int(整數),如 1,只有一種整數型別 int,表示為長整形,沒有 python2 中的 Long。
- bool(布林),如 true
- float(浮點數),如1.25、3E - 2
- complex(複數),如 1 + 2j、1.1 + 2.2j
字串(String)
- python 中單引號和雙引號使用完全相同
- 使用三引號('''或""")可以指定一個多行字串。
- 轉義符 ""
- 反斜槓可以用來轉義,使用 r 可以讓反斜杆不發生轉義。如 r"this is a line with \n"。
- 按字面意義級聯字串,如“this”"is" "string" 會被自動轉換為 this is string。
- 字串可以用 + 運算子連線在一起,用 * 運算子重複。
- Python 中的字串有兩種索引方式,從左往右以 0 開始,從右往左以 -1 開始。
- Python 中的字串不能改變。
- Python 沒有單獨的字元型別,一個字元就是長度為 1 的字串。
- 字串的擷取的語法格式如下:變數[頭下標:尾下標]
word = '字串'sentence = "這是一個句子"paragraph = """這是一個段落,可以由多行組成"""
複製程式碼
例項
str='KeepOnCode'print(str) # 輸出字串print(str[0:-1]) # 輸出第一個到倒數第二個的所有字元print(str[0]) # 輸出字串第一個字元print(str[2:5]) # 輸出從第三個開始到第五個的字元print(str[2:]) # 輸出從第三個開始的後的所有字元print(str * 2) # 輸出字串兩次print(str + '你好') # 連線字串print('------------------------------')print('hello\Koc') # 使用反斜槓(\)+n轉義特殊字元print(r'hello\Koc') # 在字串前面新增一個 r,表示原始字串,不會發生轉義
複製程式碼
空行
函式之間或類的方法之間用空行分隔,表示一段新的程式碼的開始。
類和函式入口之間也用一行空行分隔,以突出函式入口的開始。
空行與程式碼縮排不同,空行並不是 Python 語法的一部分。書寫時不插入空行,python 直譯器執行也不會出錯。但是空行的作用在於分隔兩段不同功能或含義的程式碼,便於日後程式碼的維護或重構。
記住: 空行也是程式程式碼的一部分。
等待使用者輸入
執行下面的程式在按Enter鍵後就會等待使用者輸入:
input("\n\n按下 enter 鍵後退出")
複製程式碼
以上程式碼中 ,"\n\n"在結果輸出前會輸出兩個新的空行。一旦使用者按下 enter 鍵時,程式將退出。
同一行顯示多條語句
Python 可以在同一行中使用多條語句,語句之間使用分號(;)分割,以下是一個簡單的例項:
import sys;x = 'Koc';sys.stdout.writ(x + '\n')
複製程式碼
執行以上程式碼,輸出結果為:
Koc7
複製程式碼
多個語句構成程式碼組
縮排相同的一組語句構成一個程式碼塊,我們稱之為程式碼組。
像 if、while、def 和 class 這樣的複合語句,首行以關鍵字開始,以冒號(:)結束,該行之後的一行或多行程式碼構成程式碼組。
我們將首行及後面的程式碼組稱為一個子句(clause)。
例項:
if expression : suiteelif expression : suite else : suite
複製程式碼
Print 輸出
print 預設輸出是換行的,如果要實現不換行需要在變數末尾加上 end="":
x = "a"y = "b"print( x )print( y )print('-------')print( x, end=" ")print( y, end=" ")
複製程式碼
import 與 from…import
在 python 用 import 或者 from..import 用來匯入相應的模組。
將整個模組(somemodule)匯入,格式為:import somemodule
從某個模組中匯入某個函式,格式為:from somemodule import somefunction
從某個模組中匯入多個函式,格式為:from somemodule import firstfunc,secondfunc,thirdfunc
將某個模組中的全部函式匯入,格式為:from somemodule import *
匯入 sys 模組
import sysprint('================Python import mode==========================');print ('命令列引數為:')for i in sys.argv: print (i)print ('\n python 路徑為',sys.path)
複製程式碼
匯入 sys 模組的 argv,path 成員
from sys import argv,path # 匯入特定的成員print('================python from import===================================')print('path:',path) # 因為已經匯入path成員,所以此處引用時不需要加sys.path
複製程式碼
命令列引數
很多程式可以執行一些操作來檢視一些基本資訊,Python 可以使用 -h 引數檢視各引數幫助資訊
$ python -husage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...Options and arguments (and corresponding environment variables):-c cmd : program passed in as string (terminates option list)-d : debug output from parser (also PYTHONDEBUG=x)-E : ignore environment variables (such as PYTHONPATH)-h : print this help message and exit[ etc. ]
複製程式碼
寫在最後
至此「從零開始學習 Python 之基礎語法」就已結束。今天這篇文章大多是一些概念性的介紹,但在程式設計中是屬於非常重要的內容。給自己三分鐘的時間,閉上眼來回想下,今天這篇你都學習到了什麼。
如果你按我說的去做,你會發現你只能回憶起一些內容,很難把全部的知識都記住。這是非常正常的情況,所以需要你溫故而知新,時常回顧。在最後我把今天的知識點做出思維導圖送給大家。