
作者| 陳祥安
來(lái)源|Python學(xué)習(xí)開(kāi)發(fā)
這篇文章主要和大家分享一些 Python 不一樣的技巧,雖然鮮為人知,但非常實(shí)用喔!下面就跟隨我一起來(lái)感受 Python 帶給你的樂(lè)趣吧。
1.print 打印帶有顏色的信息
大家知道 Python 中的信息打印函數(shù) Print,一般我們會(huì)使用它打印一些東西,作為一個(gè)簡(jiǎn)單調(diào)試。
但是你知道么,這個(gè) Print 打印出來(lái)的字體顏色是可以設(shè)置的。
一個(gè)小例子
def esc(code=0): return f'\033[{code}m' print(esc('31;1;0') + 'Error:'+esc()+'important')
在控制臺(tái)或者 Pycharm 運(yùn)行這段代碼之后你會(huì)得到結(jié)果。
Error:important
其中 Error 是紅色加下劃線的,important 為默認(rèn)色
其設(shè)置格式為:\033[顯示方式;前景色;背景色 m
下面可以設(shè)置的參數(shù):
說(shuō)明: 前景色 背景色 顏色 --------------------------------------- 30 40 黑色 31 41 紅色 32 42 綠色 33 43 黃色 34 44 藍(lán)色 35 45 紫紅色 36 46 青藍(lán)色 37 47 白色 顯示方式 意義 ------------------------- 0 終端默認(rèn)設(shè)置 1 高亮顯示 4 使用下劃線 5 閃爍 7 反白顯示 8 不可見(jiàn) 例子: \033[1;31;40m <!--1-高亮顯示 31-前景色紅色 40-背景色黑色-->
2.在 Python 中使用定時(shí)器
今天看到一個(gè)比較人性化的定時(shí)模塊 schedule,目前 star 數(shù)為 6432,還是非常的受歡迎,這個(gè)模塊也是秉承這 For Humans 的原則,這里推薦給大家。地址:dbader/schedule
1.通過(guò) pip 即可安裝。
pip install schedule
2.使用案例
import schedule import time def job(): print("I'm working...") schedule.every(10).minutes.do(job) schedule.every().hour.do(job) schedule.every().day.at("10:30").do(job) schedule.every().monday.do(job) schedule.every().wednesday.at("13:15").do(job) schedule.every().minute.at(":17").do(job) while True: schedule.run_pending() time.sleep(1)
從單詞的字面意思,你就知道這是做什么的。
舉個(gè)例子:
schedule.every().monday.do(job)
這句代碼作用就是就是單詞意思,定時(shí)器會(huì)每個(gè)周一運(yùn)行函數(shù) job,怎么樣是不是很簡(jiǎn)單。
3.實(shí)現(xiàn)一個(gè)進(jìn)度條
from time import sleep def progress(percent=0, width=30): left = width * percent // 100 right = width - left print('\r[', '#' * left, ' ' * right, ']', f' {percent:.0f}%', sep='', end='', flush=True) for i in range(101): progress(i) sleep(0.1)
展示效果
別臥槽了,趕緊快試試吧。
上面的代碼中的 print 有幾個(gè)有用的參數(shù),sep 的作用是已什么為分隔符,默認(rèn)是空格,這里設(shè)置為空串是為了讓每個(gè)字符之間更緊湊,end 參數(shù)作用是已什么結(jié)尾,默認(rèn)是回車(chē)換行符,這里為了實(shí)現(xiàn)進(jìn)度條的效果,同樣設(shè)置為空串。還有最后一個(gè)參數(shù) flush,該參數(shù)的作用主要是刷新, 默認(rèn) flush = False,不刷新,print 到 f 中的內(nèi)容先存到內(nèi)存中;而當(dāng) flush = True 時(shí)它會(huì)立即把內(nèi)容刷新并輸出。
4.優(yōu)雅的打印嵌套類(lèi)型的數(shù)據(jù)
大家應(yīng)該都有印象,在打印 json 字符串或者字典的時(shí)候,打印出的一坨東西根本就沒(méi)有一個(gè)層次關(guān)系,這里主要說(shuō)的就是輸出格式的問(wèn)題。
import json my_mapping = {'a': 23, 'b': 42, 'c': 0xc0ffee} print(json.dumps(my_mapping, indent=4, sort_keys=True))
大家可以自己試試只用 print 打印 my_mapping,和例子的這種打印方法。
如果我們打印字典組成的列表呢,這個(gè)時(shí)候使用 json 的 dumps 方法肯定不行的,不過(guò)沒(méi)關(guān)系
用標(biāo)準(zhǔn)庫(kù)的 pprint 方法同樣可以實(shí)現(xiàn)上面的方法
import pprint my_mapping = [{'a': 23, 'b': 42, 'c': 0xc0ffee},{'a': 231, 'b': 42, 'c': 0xc0ffee}] pprint.pprint(my_mapping,width=4)
5.功能簡(jiǎn)單的類(lèi)使用 namedtuple 和 dataclass 的方式定義
有時(shí)候我們想實(shí)現(xiàn)一個(gè)類(lèi)似類(lèi)的功能,但是沒(méi)有那么復(fù)雜的方法需要操作的時(shí)候,這個(gè)時(shí)候就可以考慮下下面兩種方法了。
第一個(gè),namedtuple 又稱具名元組,帶有名字的元組。它作為 Python 標(biāo)準(zhǔn)庫(kù) collections 里的一個(gè)模塊,可以實(shí)現(xiàn)一個(gè)類(lèi)似類(lèi)的一個(gè)功能。
from collections import namedtuple # 以前簡(jiǎn)單的類(lèi)可以使用 namedtuple 實(shí)現(xiàn)。 Car = namedtuple('Car', 'color mileage') my_car = Car('red', 3812.4) print(my_car.color) print(my_car)
但是呢,所有屬性需要提前定義好才能使用,比如想使用my_car.name,你就得把代碼改成下面的樣子。
from collections import namedtuple # 以前簡(jiǎn)單的類(lèi)可以使用 namedtuple 實(shí)現(xiàn)。 Car = namedtuple('Car', 'color mileage name') my_car = Car('red', 3812.4,"Auto") print(my_car.color) print(my_car.name)
使用 namedtuple 的缺點(diǎn)很明顯了。
所以現(xiàn)在更優(yōu)的方案,那就是 Python3.7 加入到標(biāo)準(zhǔn)庫(kù)的 dataclass。
其實(shí)在 3.6 也可以使用不過(guò)需要它被作為第三方的庫(kù)使用了,使用 pip 安裝即可。
使用示例如下:
from dataclasses import dataclass @dataclass class Car: color: str mileage: float my_car = Car('red', 3812.4) print(my_car.color) print(my_car)
6.f-string 的 !r,!a,!s
f-string出現(xiàn)在Python3.6,作為當(dāng)前最佳的拼接字符串的形式,看下 f-string 的結(jié)構(gòu)
f ' <text> { <expression> <optional !s, !r, or !a> <optional : format specifier> } <text> ... '
其中'!s' 在表達(dá)式上調(diào)用str(),'!r' 調(diào)用表達(dá)式上的repr(),'!a' 調(diào)用表達(dá)式上的ascii()
(1.默認(rèn)情況下,f-string將使用str(),但如果包含轉(zhuǎn)換標(biāo)志,則可以確保它們使用repr () !
class Comedian: def __init__(self, first_name, last_name, age): self.first_name = first_name self.last_name = last_name self.age = age def __str__(self): return f"{self.first_name} {self.last_name} is {self.age}." def __repr__(self): return f"{self.first_name} {self.last_name} is {self.age}. Surprise!"
調(diào)用
>>> new_comedian = Comedian("Eric", "Idle", "74") >>> f"{new_comedian}" 'Eric Idle is 74.' >>> f"{new_comedian}" 'Eric Idle is 74.' >>> f"{new_comedian!r}" 'Eric Idle is 74. Surprise!'
(2.!a的例子
>>> a = 'some string' >>> f'{a!r}' "'some string'"
等價(jià)于
>>> f'{repr(a)}' "'some string'"
(3.!d的例子
類(lèi)似2
pycon2019有人提出的一個(gè)展望!d的功能實(shí)現(xiàn):
在python3.8中已經(jīng)實(shí)現(xiàn)上述功能,不過(guò)不再使用!d了改為了f"{a=}"的形式,看過(guò)這個(gè)視頻的發(fā)現(xiàn)沒(méi)有!d應(yīng)該很懵逼
7.f-string 里"="的應(yīng)用
在 Python3.8 里有這樣一個(gè)功能
a = 5 print(f"{a=}")
打印之后的結(jié)果為
a=5
是不是很方便,不用你再使用f"a={a}"了。
8.海象運(yùn)算符:=的是使用
a =6 if b:=a+1>6: print(b)
賦值的時(shí)候同時(shí)可以進(jìn)行運(yùn)算,和 Go 語(yǔ)言的賦值類(lèi)似了。
代碼的運(yùn)行順序,首先計(jì)算 a+1 得到值為 7,然后把 7 賦值給 b,到這里代碼相當(dāng)于下面這樣了
b =7 if b>6: print(b)
怎么樣是不是簡(jiǎn)單了不少,不過(guò)這個(gè)功能 3.8 開(kāi)始才能用哦。
數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼
若不方便掃碼,搜微信號(hào):CDAshujufenxi
LSTM 模型輸入長(zhǎng)度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)家族中,長(zhǎng)短期記憶網(wǎng)絡(luò)(LSTM)憑借其解決長(zhǎng)序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報(bào)考條件詳解與準(zhǔn)備指南? ? 在數(shù)據(jù)驅(qū)動(dòng)決策的時(shí)代浪潮下,CDA 數(shù)據(jù)分析師認(rèn)證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計(jì)的實(shí)用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強(qiáng)大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠(chéng)摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實(shí)施重大更新。 此次更新旨在確保認(rèn) ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務(wù)的價(jià)值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡(jiǎn)稱 BI)深度融合的時(shí)代,BI ...
2025-07-10SQL 在預(yù)測(cè)分析中的應(yīng)用:從數(shù)據(jù)查詢到趨勢(shì)預(yù)判? ? 在數(shù)據(jù)驅(qū)動(dòng)決策的時(shí)代,預(yù)測(cè)分析作為挖掘數(shù)據(jù)潛在價(jià)值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價(jià)值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點(diǎn),而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報(bào)考到取證的全攻略? 在數(shù)字經(jīng)濟(jì)蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭(zhēng)搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢(shì)性檢驗(yàn):捕捉數(shù)據(jù)背后的時(shí)間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢(shì)性檢驗(yàn)如同一位耐心的偵探,專(zhuān)注于從單 ...
2025-07-09year_month數(shù)據(jù)類(lèi)型:時(shí)間維度的精準(zhǔn)切片? ? 在數(shù)據(jù)的世界里,時(shí)間是最不可或缺的維度之一,而year_month數(shù)據(jù)類(lèi)型就像一把精準(zhǔn) ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應(yīng)用與實(shí)戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認(rèn)證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗(yàn):數(shù)據(jù)趨勢(shì)與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準(zhǔn)確捕捉數(shù)據(jù)的趨勢(shì)變化以及識(shí)別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認(rèn)證作為國(guó)內(nèi)權(quán)威的數(shù)據(jù)分析能力認(rèn)證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應(yīng)對(duì)策略? 長(zhǎng)短期記憶網(wǎng)絡(luò)(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的一種變體,憑借獨(dú)特的門(mén)控機(jī)制,在 ...
2025-07-07統(tǒng)計(jì)學(xué)方法在市場(chǎng)調(diào)研數(shù)據(jù)中的深度應(yīng)用? 市場(chǎng)調(diào)研是企業(yè)洞察市場(chǎng)動(dòng)態(tài)、了解消費(fèi)者需求的重要途徑,而統(tǒng)計(jì)學(xué)方法則是市場(chǎng)調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書(shū)考試全攻略? 在數(shù)字化浪潮席卷全球的當(dāng)下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動(dòng)力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專(zhuān)業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準(zhǔn)確性的基礎(chǔ) ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動(dòng)力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開(kāi)啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價(jià)值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03