文章詳情頁
python是怎么實現(xiàn)過濾 #注釋代碼的?
瀏覽:117日期:2022-08-15 11:47:21
問題描述
今天看python核心編程看到一個問題,題意大概就是過濾一個file-like對象里“#”的注釋部分,然后輸出其他部分。簡單情形下,另寫一行的#注釋比較好判斷,用startwith(’#’)匹配應(yīng)該能滿足。問題在于那些寫在正常業(yè)務(wù)代碼之后的注釋,該如何過濾之?舉個例子:
if name.find(',') == -1:#Annotations pass
請問有沒有人了解它是怎么過濾這種注釋的?謝謝。
問題解答
回答1:講下思路如果不考慮字符串中的#,那么很方便,用re匹配
#[^n]*?n
即可如果考慮到字符串中的#稍微復雜些,匹配:
#[^’']*?n
勉強能應(yīng)付大多數(shù)情況
缺點是對于
’a’ # ’b’
這樣的語句匹配不了,因為Python的re不支持平衡組。
回答2:直接用正則匹配#到行尾不就得了。
相關(guān)文章:
1. 編輯成功不顯示彈窗2. mysql - 表名稱前綴到底有啥用?3. Navicat for mysql 中以json格式儲存的數(shù)據(jù)存在大量反斜杠,如何去除?4. mysql - 數(shù)據(jù)庫表中,兩個表互為外鍵參考如何解決5. 哭遼 求大佬解答 控制器的join方法怎么轉(zhuǎn)模型方法6. mysql儲存json錯誤7. mysql - 怎么生成這個sql表?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現(xiàn)存在即更新應(yīng)該使用哪個標簽?9. sql語句 - 如何在mysql中批量添加用戶?10. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。
排行榜

熱門標簽