亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

用 Python 的“wget”覆蓋現有文件?

用 Python 的“wget”覆蓋現有文件?

MYYA 2023-04-25 16:09:49
我已經在我的 Python 上安裝了 wget,我正在用它從不同的 URL 下載文件。到目前為止,我的代碼如下所示:import wgeturls = ['https://www.iedb.org/downloader.php?file_name=doc/epitope_full_v3.zip',         'https://www.iedb.org/downloader.php?file_name=doc/tcell_full_v3.zip',        'https://www.iedb.org/downloader.php?file_name=doc/bcell_full_v3.zip',         'https://www.iedb.org/downloader.php?file_name=doc/mhc_ligand_full_single_file.zip']path = '/home/david/data/files/zip_files'for url in urls:   wget.download(url, path)我希望我的代碼覆蓋下載的文件(如果它們存在),這樣每次我運行代碼時我都會獲得該文件的最新版本,而不是保留舊文件并下載具有不同名稱的新文件(例如,如果epitope_full_v3.zip 已經存在,當我執行代碼時它會再次下載,但會保留舊的并將新的重命名為 epitope_full_v3_1.zip)。我知道 wget 可以在 shell 中使用 -O 參數來允許你這樣做,但我沒有在文檔中看到 python 版本的參數。我感謝您的幫助。
查看完整描述

1 回答

?
蕪湖不蕪

TA貢獻1796條經驗 獲得超7個贊

雖然wget沒有提到,你可以自己改變它。使用os.path.basename()獲取文件名,并檢查它是否存在。像這樣:


import wget

import os


urls = ['https://www.iedb.org/downloader.php?file_name=doc/epitope_full_v3.zip',

        'https://www.iedb.org/downloader.php?file_name=doc/tcell_full_v3.zip',

        'https://www.iedb.org/downloader.php?file_name=doc/bcell_full_v3.zip',

        'https://www.iedb.org/downloader.php?file_name=doc/mhc_ligand_full_single_file.zip']


path = '/home/david/data/files/zip_files'


for url in urls:

    filename = path + '/' + os.path.basename(url) # get the full path of the file

    if os.path.exists(filename):

        os.remove(filename) # if exist, remove it directly

    wget.download(url, out=filename) # download it to the specific path.


查看完整回答
反對 回復 2023-04-25
  • 1 回答
  • 0 關注
  • 205 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號