
作者| 陳祥安
來(lái)源|Python學(xué)習(xí)開發(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 不可見 例子: \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)是回車換行符,這里為了實(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)雅的打印嵌套類型的數(shù)據(jù)
大家應(yīng)該都有印象,在打印 json 字符串或者字典的時(shí)候,打印出的一坨東西根本就沒有一個(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ò)沒關(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)單的類使用 namedtuple 和 dataclass 的方式定義
有時(shí)候我們想實(shí)現(xiàn)一個(gè)類似類的功能,但是沒有那么復(fù)雜的方法需要操作的時(shí)候,這個(gè)時(shí)候就可以考慮下下面兩種方法了。
第一個(gè),namedtuple 又稱具名元組,帶有名字的元組。它作為 Python 標(biāo)準(zhǔn)庫(kù) collections 里的一個(gè)模塊,可以實(shí)現(xiàn)一個(gè)類似類的一個(gè)功能。
from collections import namedtuple # 以前簡(jiǎn)單的類可以使用 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)單的類可以使用 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的例子
類似2
pycon2019有人提出的一個(gè)展望!d的功能實(shí)現(xiàn):
在python3.8中已經(jīng)實(shí)現(xiàn)上述功能,不過(guò)不再使用!d了改為了f"{a=}"的形式,看過(guò)這個(gè)視頻的發(fā)現(xiàn)沒有!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ǔ)言的賦值類似了。
代碼的運(yùn)行順序,首先計(jì)算 a+1 得到值為 7,然后把 7 賦值給 b,到這里代碼相當(dāng)于下面這樣了
b =7 if b>6: print(b)
怎么樣是不是簡(jiǎn)單了不少,不過(guò)這個(gè)功能 3.8 開始才能用哦。
數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼
若不方便掃碼,搜微信號(hào):CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實(shí)戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無(wú)論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫(kù)管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫(kù)表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預(yù)期算子的內(nèi)涵、作用與應(yīng)用解析 動(dòng)態(tài)隨機(jī)一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結(jié)構(gòu)數(shù)據(jù)特征價(jià)值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫(kù)表、Excel 表、 ...
2025-09-17Excel 導(dǎo)入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實(shí)戰(zhàn)應(yīng)用 在用 Python(如 pandas 庫(kù))處理 Excel 數(shù)據(jù)時(shí),“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗(yàn)與 t 檢驗(yàn):差異、適用場(chǎng)景與實(shí)踐應(yīng)用 在數(shù)據(jù)分析與統(tǒng)計(jì)學(xué)領(lǐng)域,假設(shè)檢驗(yàn)是驗(yàn)證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計(jì)劃中 rows 數(shù)量的準(zhǔn)確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計(jì)劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對(duì)象的 text 與 content:區(qū)別、場(chǎng)景與實(shí)踐指南 在 Python 進(jìn)行 HTTP 網(wǎng)絡(luò)請(qǐng)求開發(fā)時(shí)(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價(jià)值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫(kù)表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請(qǐng)求工具對(duì)比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請(qǐng)求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長(zhǎng)浮點(diǎn)數(shù)據(jù)的科學(xué)計(jì)數(shù)法問(wèn)題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長(zhǎng)浮點(diǎn)數(shù)據(jù)時(shí)的科學(xué)計(jì)數(shù)法問(wèn)題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價(jià)值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運(yùn)營(yíng)問(wèn)題、提升執(zhí)行效率的核心手段,其價(jià)值 ...
2025-09-12用 SQL 驗(yàn)證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實(shí)戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過(guò)程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計(jì)” 與 “用戶體驗(yàn) ...
2025-09-11塔吉特百貨孕婦營(yíng)銷案例:數(shù)據(jù)驅(qū)動(dòng)下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當(dāng)下,精準(zhǔn)營(yíng)銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務(wù)數(shù)據(jù)分析:概念辨析與協(xié)同價(jià)值 在數(shù)據(jù)驅(qū)動(dòng)決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務(wù)數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實(shí)踐到業(yè)務(wù)價(jià)值挖掘 在數(shù)據(jù)分析場(chǎng)景中,聚類分析作為 “無(wú)監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計(jì)模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價(jià)值導(dǎo)向 統(tǒng)計(jì)模型作為數(shù)據(jù)分析的核心工具,并非簡(jiǎn)單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10