linux - 下面這條shell命令怎么用python寫啊?
問題描述
最初的腳本是一個前輩維護的,shell腳本,太難懂了,老大讓我重新用python寫一遍,功能如下,就是獲取svn log中的時間戳字段]我按照python的寫法,將命令拼接起來,調用popen執行。
但是運行的時候報錯了,如下所示:
然后我測了下cmd的前面部分,也就是他的結果是:
可見結果是正確的,所以判斷問題就出現在sed這部分,還請各位前輩幫忙看看。
問題解答
回答1:你把命令直接復制到命令行能用嗎?如果能用就是你組織字符串出的錯,比如雙引號被你漏了,比如python中'%F'與’'%F'’是不一樣的,還有’2’與’2’是不一樣的
回答2:剛開始工作,太拘泥于別人的思路了,我想了下直接盡可能的用python來實現功能。用python的替換功能搞定問題就好了
不用sed/grep...
# coding: utf8import re from time import strftime, strptimefrom subprocess import Popen, PIPEcmd = ’svn log’ # 不需要sedresult = Popen(cmd, shell=True, stdout=PIPE, stderr=PIPE)stdout, stderr = result.communicate()for _ in re.findall(r’(?<=date>)([^<.]+).’, stdout): print(strftime('%F %T', strptime(_, '%Y-%m-%dT%H:%M:%S')))
相關文章:
1. 查詢mysql數據庫中指定表指定日期的數據?有詳細2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
