开源软件批量下载
- 作者: 三爪猫60212662
- 来源: 51数据库
- 2022-08-12
import requests
import lxml
import gevent
from lxml import html
import os
from gevent import monkey; monkey.patch_os()
monkey.patch_socket()
from multiprocessing import Process
#view-source:https://repos.fedorapeople.org/repos/openstack/openstack-icehouse/epel-6/epel/
base_url = "https://repos.fedorapeople.org/repos/openstack/openstack-icehouse/epel-6/epel/"
url_send="https://repos.fedorapeople.org/repos/openstack/openstack-icehouse/epel-6/"
repodata_url ="https://repos.fedorapeople.org/repos/openstack/openstack-icehouse/epel-6/repodata/"
puppetlab = "http://www.51sjk.com/Upload/Articles/1/0/320/320348_20220812153741745.jpg"
def get_rpms(url):
r = requests.get( url )
doc = html.fromstring(r.text)
doc.make_links_absolute( url )
links = doc.iterlinks()
rpms = [i[2] for i in links if i[2].endswith("rpm")]
return rpms
def get_gzs(url):
r = requests.get(url)
doc = html.fromstring(r.text)
doc.make_links_absolute(url)
links = doc.iterlinks()
rpms = [i[2] for i in links if i[2].endswith("gz") or i[2].endswith("bz2")]
return rpms
def download(url, dir):
r = requests.get( url )
filename = url.split("/")[-1]
print(filename)
f = open( os.path.join(dir, filename) , "wb")
f.write(r.content)
f.close()
rpms = get_rpms ( puppetlab )
w = []
for i in rpms:
print(i)
g = gevent.spawn(download, i, "puppetlab",)
w.append(g)
gevent.joinall(w)
gevent.sleep(0.3)
推荐阅读
热点文章
Discord.py(重写)on_member_update 无法正常工作
0
Discord.py 在 vc 中获取用户分钟数
0
discord.py 重写 |为我的命令出错
0
Discord.py rewrite 如何 DM 命令?
0
播放音频时,最后一部分被切断.如何解决这个问题?(discord.py)
0
在消息删除消息 Discord.py
0
如何使 discord.py 机器人私人/直接消息不是作者的人?
0
(Discord.py) 如何获取整个嵌入内容?
0
Discord bot 尽管获得了许可,但不能提及所有人
0
Discord.py discord.NotFound 异常
0
