91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python3.8中使用f-strings調試

發布時間:2020-08-29 21:47:25 來源:腳本之家 閱讀:148 作者:小明明S 欄目:開發技術

前言

我日常開發大概有98%的情況下會使用print來調試(別說pdb之類的, 根本不實用),通過在合適的位置插入print語句打印出要跟蹤的表達式或者變量的值來確認問題。f-string讓格式化這件事變得美觀簡單,但是依然對調試毫無幫助。

我舉個例子:

s = 'A string'
value = 123

如果你想看運行時s和value的值分別是多少(PS: 這里演示的是常量,在實際代碼執行中可能他們是表達式或者函數調用計算出來的,那時它們就是動態的了),可以在代碼中加一行print打印一下它們:

s = 'A string'
value = 123
print(s, value) # 新插入的行

這樣就能通過日志或者終端知道s和value是什么了。不過,這樣做的問題是,通過輸出對應s和value是不明確的,你需要非常清晰的了解代碼邏輯;如果代碼中有多個print,每個print都是2個參數,就麻煩了:

s = 'A string'
value = 123
print(s, value)
o = 'Other String'
rv = 234
print(o, rv) # 另外一個print

你還得用某種方法區分他們都是從哪行打印出來的:

s = 'A string'
value = 123
print(s, value, 'S')
o = 'Other String'
rv = 234
print(o, rv, 'Other')

這是我常用的方案,多加一個參數,通過第三項幫你確認分別是哪行打印出來的。

好的寫法需要明確你要跟蹤的變量和值的對應關系。可以這樣寫:

>>> print(f's={s!r}, value={value}')
s='A string', value=123
>>> print(f'o={o!r}, rv={rv}')
o='Other String', rv=234

大括號里面的除了有變量,后面還加個 !r ,它是一個轉換標志(conversion flag),在過去的format格式化方法中也有。一共有三種轉換標志,另外2個分別是 !a 和 !s ,我們感受一下:

>>> '{!a}'.format('哈哈') # 相當于 ascii('哈哈')
"'\\u54c8\\u54c8'"
>>> '{!s}'.format('哈哈') # 相當于 str('哈哈')
'哈哈'
>>> '{!r}'.format('哈哈') # 相當于 repr('哈哈')
"'哈哈'"

上面的例子中, {s!r} 就是對變量s執行 str(s) ,不用(不應該)這樣寫:

>>> print(f's={s}')
s=A string # 注意,沒有引號,空格把值分開了,有多個值的話就不容易辨識
>>> print(f's="{s}"') # 不用`!r`需要手動加引號
s="A string"

不管怎么說,這樣其實已經算不錯的了,雖然當要打印的變量比較多的時候print語句非常長...

Python 3.8中f-strings的'='

這個功能還是看PyCON2019的閃電演講看到的,f-strings的作者Eric V. Smith接受了Larry Hastings的意見實現了f-string的調試功能。本來是想另外一個轉換標識 !d ,效果大概是這樣:

value = 10
s = 'a string!'
print(f'{value!d}')
print(f'next: {value+1!d}')
print(f'{s!d}')
print(f'{s!d:*^20}')
print(f'*{value!d:^20}*')
# 輸出
value=10
next: value+1=11
s='a string!'
'****s="A string"****'
*   value=10   *

也就是說,f-strings自動添加 變量名 + = ,而且支持補齊空位還能做表達式求值,如上例, {value+1!d} 表示計算 value+1 再打印出來。

不過后來作者和Guido討論,改用了更靈活的 = 。現在已經合并到Python3.8,我們可以真實的試用了:

❯ ./python.exe
Python 3.8.0a4+ (heads/master:2725cb01d7, May 22 2019, 10:29:22)
...
>>> print(f'{s=}, {value=}')
s='A string', value=123
>>> print(f'{o=}, {rv=}')
o='Other String', rv=234
>>> print(f'{value / 3 + 15=}')
value / 3 + 15=56.0
>>> print(f'{s=:*^20}')
s=******A string******
>>> print(f'*{s=:^20}*')
*s=   A string   *

為啥我說用 = 更靈活呢,再看幾個混合轉換標識的例子:

>>> x = '哈哈'
>>> f'{x=}'
"x='哈哈'"
>>> f'{x=!s}'
'x=哈哈'
>>> f'{x=!r}'
"x='哈哈'"
>>> f'{x=!a}'
"x='\\u54c8\\u54c8'"
>>> f'{x=!s:^20}'
'x=     哈哈     '

就是說,DEBUG模式可以和轉換標識一起用!

學到了吧?開始期待Python3.8了~

PS: 如果你看了PyCON的那個「Easier debugging with f-strings」的演講(延伸閱讀鏈接2),其中還是說用 !d ,其實演講后第二天就改成了 = 了,要注意哈~

總結

以上所述是小編給大家介紹的Python3.8中使用f-strings調試,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

婺源县| 郴州市| 平顶山市| 阿勒泰市| 无极县| 囊谦县| 泸水县| 炎陵县| 江源县| 定安县| 平乐县| 黔东| 邵武市| 久治县| 砀山县| 南投市| 名山县| 光泽县| 耒阳市| 钦州市| 赤水市| 沙坪坝区| 综艺| 苗栗市| 平定县| 永年县| 科技| 长武县| 峨山| 镇原县| 泌阳县| 北安市| 砚山县| 奉化市| 云林县| 莲花县| 丰原市| 南京市| 麻栗坡县| 襄城县| 阿坝|