從零開始學 Python 之基礎語法

weixin_34370347發表於2018-03-27

前言

大家好,這裡是首發於「痴海」公眾號的從零開始學習 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 之基礎語法」就已結束。今天這篇文章大多是一些概念性的介紹,但在程式設計中是屬於非常重要的內容。給自己三分鐘的時間,閉上眼來回想下,今天這篇你都學習到了什麼。

如果你按我說的去做,你會發現你只能回憶起一些內容,很難把全部的知識都記住。這是非常正常的情況,所以需要你溫故而知新,時常回顧。在最後我把今天的知識點做出思維導圖送給大家。

20180326

相關文章