99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁(yè)精彩閱讀你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?
你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?
2019-09-16
收藏
你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?

作者| 陳祥安

來(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-背景色黑色-->

你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?


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)

展示效果

你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?

別臥槽了,趕緊快試試吧。

你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?

上面的代碼中的 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)

你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?


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)

你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?


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):

你怎能錯(cuò)過(guò)這幾個(gè)鮮為人知但很實(shí)用的 Python 技巧?

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

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個(gè)參數(shù)驗(yàn)證碼對(duì)象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個(gè)配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺(tái)檢測(cè)極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時(shí)表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說(shuō)明請(qǐng)參見(jiàn):http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時(shí)完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請(qǐng)輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請(qǐng)輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }