標題無意冒犯,就是覺得這個廣告挺好玩的
上面這張思維導圖喜歡就拿走,反正我也學不了這麼多
前期回顧:我要偷偷學Python,然後驚呆所有人(第三天)
上面這篇裡面寫了python的一些知識基礎,主要是Python對於檔案的讀寫操作,可能是字數比較少吧,每次我自己點開都覺得有點尷尬。
但是也是因為檔案讀寫相對於前面兩篇會比較難一點吧
那麼今天,我們就看一下能讓Python成為‘萬金油’的東西,模組!如果對基礎還不是很熟練的話可以再紮實一下基礎,畢竟萬丈高樓平地起嘛,基礎不老實是很危險的。
本系列文預設各位有一定的C或C++基礎,因為我是學了點C++的皮毛之後入手的Python,這裡也要感謝齊鋒學長送來的支援。
本系列文預設各位會百度,學習‘模組’這個模組的話,還是建議大家有自己的編輯器和編譯器的,上一篇已經給大家做了推薦啦?
我要的不多,點個關注就好啦
然後呢,本系列的目錄嘛,說實話我個人比較傾向於那兩本 Primer Plus,所以就跟著它們的目錄結構吧。
本系列也會著重培養各位的自主動手能力,畢竟我不可能把所有知識點都給你講到,所以自己解決需求的能力就尤為重要,所以我在文中埋得坑請不要把它們看成坑,那是我留給你們的鍛鍊機會,請各顯神通,自行解決。
好,接下來切入正題。
如果有學過其他高階語言的朋友就會知道,在C/C++的原始檔開頭,一般都會有一大堆的‘include’,這是參照標頭檔案,一個標頭檔案當中會有一些比方說類、函數、變數等等,而你要使用這些東西,你就要事先做一個宣告。
這樣講實在是太空泛了。
假設現在有個QQ群,群裡有成員,有檔案資料,有聊天記錄,你要獲取這些東西並使用,你是不是得加群?
掉用模組就是這個道理,模組裡面有類、有函數、有變數,你要使用這些東西,你就得匯入模組。
這樣講就通暢多了嘛。
emmm,總覺得還是少了點什麼,對,我們來掃描一個模組,瞟一眼就好啊,不求看懂,大概知道里面是啥,咱心裡有點數:
以下是一塊 random 模組中的擷取:
from warnings import warn as _warn
from types import MethodType as _MethodType, BuiltinMethodType as _BuiltinMethodType
from math import log as _log, exp as _exp, pi as _pi, e as _e, ceil as _ceil
from math import sqrt as _sqrt, acos as _acos, cos as _cos, sin as _sin
from os import urandom as _urandom
from _collections_abc import Set as _Set, Sequence as _Sequence
from hashlib import sha512 as _sha512
import _random
__all__ = ["Random","seed","random","uniform","randint","choice","sample",
"randrange","shuffle","normalvariate","lognormvariate",
"expovariate","vonmisesvariate","gammavariate","triangular",
"gauss","betavariate","paretovariate","weibullvariate",
"getstate","setstate", "getrandbits",
"SystemRandom"]
NV_MAGICCONST = 4 * _exp(-0.5)/_sqrt(2.0)
TWOPI = 2.0*_pi
LOG4 = _log(4.0)
SG_MAGICCONST = 1.0 + _log(4.5)
BPF = 53 # Number of bits in a float
RECIP_BPF = 2**-BPF
class Random(_random.Random):
VERSION = 3 # used by getstate/setstate
def __init__(self, x=None):
self.seed(x)
self.gauss_next = None
def seed(self, a=None, version=2):
if a is None:
try:
# Seed with enough bytes to span the 19937 bit
# state space for the Mersenne Twister
a = int.from_bytes(_urandom(2500), 'big')
except NotImplementedError:
import time
a = int(time.time() * 256) # use fractional seconds
if version == 2:
if isinstance(a, (str, bytes, bytearray)):
if isinstance(a, str):
a = a.encode()
a += _sha512(a).digest()
a = int.from_bytes(a, 'big')
super().seed(a)
self.gauss_next = None
……
可以看到,開頭那個它調了一堆的包(import…,現在看不懂沒關係),然後接下來時一些變數,接著是個類,類裡面有函數。
好,大概瞟一眼就好啊,我們繼續
定義變數需要用賦值語句,封裝函數需要用def語句,封裝類需要用class語句,但封裝模組不需要任何語句。
之所以不用任何語句,是因為每一份單獨的Python程式碼檔案(字尾名是.py的檔案)就是一個單獨的模組。
這個也不難理解吧。
封裝模組的目的也是為了把程式程式碼和資料存放起來以便再次利用。如果封裝成類和函數,主要還是便於自己呼叫,但封裝了模組,我們不僅能自己使用,檔案的方式也很容易共用給其他人使用。
怎麼說呢,別人的模組千千萬,但是學習的時候還是用自己寫的模組比較得心應手,因為以後也少不了自己寫模組的時候。
照圖中的順序,把模組新建出來,然後把程式碼寫上。
好,這是一個很簡單的小栗子。
就像上一篇的檔案開啟有兩種方法,一種直接了當的開啟,另一種用別名,這裡呼叫模組也有不同的方法。
第一種直接import已經見過了,不過這裡可以再說一點,如果模組名過長,可以取個別名
比方說import test
,你覺得test有點長,後面使用不方便,你可以這樣:import test as t
不過後面就只能用 t 來指代那個模組,而不能再用 test 了,它已經被頂包了。
第二種方法,叫 from…import…
這種方法是什麼,還是上面那個例子,我現在就想用test裡面的那個test3類,其他的我不要,那我為什麼要把其他的東西都導進來,那不是太龐大了嗎?這時候就可以用這種方法,精準定位。
看圖:
這是一個典型的錯誤寫法:既然你已經精準定位了,就不要再糾纏與以前的那個大水池了
這裡測試了一下如果只匯入某部分,其餘沒被匯入的部分被匯入部分應用會不會有衝突:
這是驗證結果:
這是別名的使用,照樣是可以使用的:
這裡再提一點,如果想要匯入多個模組呢?也是可以的,不同模組之間用逗號割開即可,大家動起來,自己嘗試一下。
if __name__ == '__main__'
對於Python和其他許多程式語言來說,程式都要有一個執行入口。
在Python中,當我們在執行某一個py檔案,就能啟動程式 ——— 這個py檔案就是程式的執行入口。
但是,當我們有了一大堆py檔案組成一個程式的時候:
為了【指明】某個py檔案是程式的執行入口,我們可以在該py檔案中寫出這樣的程式碼:
# 【檔案:xx.py】
程式碼塊 ①……
if __name__ == '__main__':
程式碼塊 ②……
這句話的意思是這樣的:
這裡的【if name == ‘main’】就相當於是 Python 模擬的程式入口。Python 本身並沒有規定這麼寫,這是一種程式設計師達成共識的編碼習慣。
首先我們要明確的知道,這是在使用別人的模組。其次我們只知道我們要實現的功能是簡單操作Excel表格。
那麼我們的順序就應該是:
我要用什麼模組?
這個模組裡有哪些功能?
這些具體功能該怎麼使用?
好的,我去用了。
這個其實很好辦,也很不好辦。
說好辦嘛,你問度娘就好啦:
是吧,一搜全都有。
說不好辦吧,很多前人的經驗你是搜不到的,你得去問。
比如說我們今天就使用csv模組,因為它簡單易上手。
那這個問題也很好辦嘛,如果覺得自己英語沒問題,或者想鍛鍊一下英語的朋友,可以去官網,因為官網是有更新到最新版的。
中文翻譯版嘛,有時候不能很有效的找到最新版。
嘿嘿,開個玩笑,中文版也有
Python手冊(官方中文版)
好,我們找到csv模組(有搜尋方塊的):CSV
有興趣的話可以連中文帶英文一起看,趕時間的話就直接看它的範例程式碼即可啦。
首先我們建個表:
然後開啟這個表,就像開啟檔案一樣,如果檔案操作還不熟練的朋友可以回到這篇溫習一下:
我要偷偷學Python(3)
import csv
with open('test.csv', newline = '', encoding = 'GBK') as f:
#引數encoding = 'utf-8'防止出現亂碼
reader = csv.reader(f)
#使用csv的reader()方法,建立一個reader物件
for row in reader:
print(row)
先建立一個變數名為writer(也可以是其他名字)的範例,建立方式是writer = csv.writer(x),然後使用writer.writerow(列表)就可以給csv檔案寫入一行列表中的內容。
import csv
with open('test.csv','a', newline='',encoding='utf-8') as f:
writer = csv.writer(f)
writer.writerow(['6', '小黑', '65', '82', '86'])
writer.writerow(['7', '小紅', '78', '64', '31'])
到這裡,最基本的csv表格讀取和錄入方法我們就已經學會了。
今日份任務:
大家嘗試一下將多個csv檔案合併到一個csv檔案中吧,這個說難其實也不難,說簡單也不是那麼的直觀啦。
下一篇我會放上我的程式碼。
然後呢,我平均三四天更一篇「偷偷學Python」系列文咯,所以大家不要著急,一切都會如期而至。
下一篇是實操文,帶大家從頭回顧這些天的學習內容,練習會比較多哦。
我建了一個Python學習答疑群,有興趣的朋友可以瞭解一下:這是個什麼群
直通群的傳送門:傳送門