说明:P
站很多人不陌生了,这里分享个爬虫脚本,基于Python3
,可直接下载排行榜、画师的原图。无需登录,无需cookies
,也不需要其它依赖,使用纯Python
原生模块,支持多线程下载,支持过滤已下载。由于官方需要登录才能下载原图,这里就绕过了官方,直接获取下载原图,毕竟不是原图就没得意义了,有需求的可以收藏下。
截图
使用
Github地址:https://github.com/MoeClub/Pixiv
要求:Python 3
、网络能访问Pixiv
站。
1、安装Python 3
#CenOS 6系统
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
yum install python34 -y
#CenOS 7系统
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
yum install python36 -y
#Debian 7、8系统
apt update
apt install python3 -y
Debian 9
、10
和Ubuntu
系统自带Python 3
,无需安装,可直接进行下一步。
2、下载脚本
wget https://raw.githubusercontent.com/MoeClub/Pixiv/master/pixiv.py
脚本默认25
线程,想改的话,直接编辑脚本,搜索25
,改成相应数字就可以了。
3、使用脚本
#下载画师原图,使用画师UID即可
python3 pixiv.py "673179"
#下载排行榜原图,使用排行榜地址即可
python3 pixiv.py "https://www.pixiv.net/ranking.php?mode=male"
版权声明:本文为原创文章,版权归 Rat's Blog 所有,转载请注明出处!
本文链接:https://www.moerats.com/archives/976/
如教程需要更新,或者相关链接出现404,可以在文章下面评论留言。
各位dalao有没有e站的爬虫脚本
我在博主代码的基础上,加入了GUI,优化了多线程(一个url对应多张图片的情况,并行度不高),加入了标签搜索,可以动态获取p站榜单的图片(selenium实现scroll down),具体可以参考https://github.com/LewisSean/pixiv_rank_web_crawler
可以,我玩玩先
大佬, 好像这个没有 scroll down 功能啊...
10月开始从浏览器访问不了,但是ping得通P站,你那边有出现类似的情况么?ins、推什么的使用正常。唯独P站无法在浏览器访问
而且很奇怪,直接在vps(美国)上运行脚本,也不行
python3 pixiv.py "https://www.pixiv.net/ranking.php?mode=male"Traceback (most recent call last):
encode_chunked=req.has_header('Transfer-encoding'))File "/usr/lib64/python3.6/urllib/request.py", line 1318, in do_open
File "/usr/lib64/python3.6/http/client.py", line 1254, in request
self._send_request(method, url, body, headers, encode_chunked)File "/usr/lib64/python3.6/http/client.py", line 1300, in _send_request
self.endheaders(body, encode_chunked=encode_chunked)File "/usr/lib64/python3.6/http/client.py", line 1249, in endheaders
self._send_output(message_body, encode_chunked=encode_chunked)File "/usr/lib64/python3.6/http/client.py", line 1036, in _send_output
self.send(msg)File "/usr/lib64/python3.6/http/client.py", line 974, in send
self.connect()File "/usr/lib64/python3.6/http/client.py", line 1407, in connect
super().connect()File "/usr/lib64/python3.6/http/client.py", line 946, in connect
(self.host,self.port), self.timeout, self.source_address)File "/usr/lib64/python3.6/socket.py", line 724, in create_connection
raise errFile "/usr/lib64/python3.6/socket.py", line 713, in create_connection
sock.connect(sa)TimeoutError: [Errno 110] Connection timed out
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
p.get_item(task)File "pixiv.py", line 147, in <module>
File "pixiv.py", line 65, in get_item
page = self._http(UserID, self.DefaultHeader, True)File "pixiv.py", line 28, in _http
res = request.urlopen(request.Request(url, headers=headers, method='GET'))File "/usr/lib64/python3.6/urllib/request.py", line 223, in urlopen
return opener.open(url, data, timeout)File "/usr/lib64/python3.6/urllib/request.py", line 526, in open
response = self._open(req, data)File "/usr/lib64/python3.6/urllib/request.py", line 544, in _open
'_open', req)File "/usr/lib64/python3.6/urllib/request.py", line 504, in _call_chain
result = func(*args)File "/usr/lib64/python3.6/urllib/request.py", line 1361, in https_open
context=self._context, check_hostname=self._check_hostname)File "/usr/lib64/python3.6/urllib/request.py", line 1320, in do_open
raise URLError(err)urllib.error.URLError: <urlopen error [Errno 110] Connection timed out>
我刚开了一台vultr试了一下,没问题,可以下载
R 18 画师的爬不下来嘛
有没有另一个P站的爬虫
有,不过不给你
dalao 分享下吧
windows端也有
https://github.com/Tsuk1ko/pxder
这个很久前发过 ,不过要登陆,没这个方便
不过下载自己点了收藏的图片就很方便
用画师uid批量下载的时候
如果下载的时候能加上作者的id或是名字就好了
已经给萌咖说了下,稍后达到你的要求。
太棒了!
第一次知道有个p站了,要登陆,丢弃
这个站好东西还是不少的