python - subprocess模塊怎樣返回執(zhí)行文件內(nèi)容?
問(wèn)題描述
如下面的代碼,調(diào)用mplayer播放本地音頻文件,是否能夠通過(guò)p獲取到filepath文件中的數(shù)據(jù)?
p=subprocess.Popen(['mplayer',filepath],shell=False,stdin=subprocess.PIPE,stderr=subprocess.PIPE)
filepath也可能是個(gè)url,需要其中的數(shù)據(jù),但是不想額外地再次訪問(wèn)這個(gè)地址。-------補(bǔ)充-------試著調(diào)試時(shí)跟進(jìn)去過(guò),想看看有沒(méi)有在調(diào)用mplayer前獲取了文件內(nèi)容,但是到了subprocess模塊里,單步調(diào)試不管用了,所以想知道是否在調(diào)用mplayer前subprocess模塊已經(jīng)拿到數(shù)據(jù),如果是那就能獲取這些數(shù)據(jù)了。
問(wèn)題解答
回答1:subprocess只是一個(gè)調(diào)用命令的庫(kù), 它的stdin, stdout也只是儲(chǔ)存 命令輸出的 結(jié)果, 如果你的命令, 在執(zhí)行過(guò)程中, 有結(jié)果,有文本或者什么別的輸出, 那么可以獲取, 但是如果你說(shuō)像解析這個(gè)音頻文件, 那應(yīng)該是不行的, 或者你需要?jiǎng)e的解析方式去解釋, 或者直接打開(kāi)那個(gè)文件, 說(shuō)不定也能得到你想要的
回答2:感覺(jué)你想獲取的是音頻數(shù)據(jù)的metadata,如實(shí)是MP3的話可以試試ID3這個(gè)庫(kù)。
相關(guān)文章:
1. 查詢mysql數(shù)據(jù)庫(kù)中指定表指定日期的數(shù)據(jù)?有詳細(xì)2. mysql - 怎么生成這個(gè)sql表?3. mysql儲(chǔ)存json錯(cuò)誤4. php - 公眾號(hào)文章底部的小程序二維碼如何統(tǒng)計(jì)?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數(shù)據(jù)庫(kù)表中,兩個(gè)表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲(chǔ)存的數(shù)據(jù)存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語(yǔ)法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?9. mysql - 數(shù)據(jù)庫(kù)建字段,默認(rèn)值空和empty string有什么區(qū)別 11010. sql語(yǔ)句 - 如何在mysql中批量添加用戶?
