温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用Python怎么编写一个论文下载器

发布时间:2021-01-18 14:38:40 来源:亿速云 阅读:183 作者:Leah 栏目:开发技术

使用Python怎么编写一个论文下载器?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

1. 搜索论文

通过论文的URL、PMID、DOI号或者论文标题等搜索到对应的论文,并通过bs4库找出PDF原文的链接地址,代码如下:

def search_article(artName):  '''  搜索论文  ---------------  输入:论文名  ---------------  输出:搜索结果(如果没有返回"",否则返回PDF链接)  '''  url = 'https://www.sci-hub.ren/'  headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0',     'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',     'Accept-Language':'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',     'Accept-Encoding':'gzip, deflate, br',     'Content-Type':'application/x-www-form-urlencoded',     'Content-Length':'123',     'Origin':'https://www.sci-hub.ren',     'Connection':'keep-alive',     'Upgrade-Insecure-Requests':'1'}  data = {'sci-hub-plugin-check':'',    'request':artName}  res = requests.post(url, headers=headers, data=data)  html = res.text  soup = BeautifulSoup(html, 'html.parser')  iframe = soup.find(id='pdf')  if iframe == None: # 未找到相应文章   return ''  else:   downUrl = iframe['src']   if 'http' not in downUrl:    downUrl = 'https:'+downUrl   return downUrl

2. 下载论文

得到了论文的链接地址之后,只需要通过requests发送一个请求,即可将其下载:

def download_article(downUrl):  '''  根据论文链接下载文章  ----------------------  输入:论文链接  ----------------------  输出:PDF文件二进制  '''  headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0',     'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',     'Accept-Language':'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',     'Accept-Encoding':'gzip, deflate, br',     'Connection':'keep-alive',     'Upgrade-Insecure-Requests':'1'}  res = requests.get(downUrl, headers=headers)  return res.content

二、完整代码

将上述两个函数整合之后,我的完整代码如下:

# -*- coding: utf-8 -*- """ Created on Tue Jan 5 16:32:22 2021 @author: kimol_love """ import os import time import requests from bs4 import BeautifulSoup   def search_article(artName):  '''  搜索论文  ---------------  输入:论文名  ---------------  输出:搜索结果(如果没有返回"",否则返回PDF链接)  '''  url = 'https://www.sci-hub.ren/'  headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0',     'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',     'Accept-Language':'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',     'Accept-Encoding':'gzip, deflate, br',     'Content-Type':'application/x-www-form-urlencoded',     'Content-Length':'123',     'Origin':'https://www.sci-hub.ren',     'Connection':'keep-alive',     'Upgrade-Insecure-Requests':'1'}  data = {'sci-hub-plugin-check':'',    'request':artName}  res = requests.post(url, headers=headers, data=data)  html = res.text  soup = BeautifulSoup(html, 'html.parser')  iframe = soup.find(id='pdf')  if iframe == None: # 未找到相应文章   return ''  else:   downUrl = iframe['src']   if 'http' not in downUrl:    downUrl = 'https:'+downUrl   return downUrl    def download_article(downUrl):  '''  根据论文链接下载文章  ----------------------  输入:论文链接  ----------------------  输出:PDF文件二进制  '''  headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0',     'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',     'Accept-Language':'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',     'Accept-Encoding':'gzip, deflate, br',     'Connection':'keep-alive',     'Upgrade-Insecure-Requests':'1'}  res = requests.get(downUrl, headers=headers)  return res.content   def welcome():  '''  欢迎界面  '''  os.system('cls')  title = '''     _____ _____ _____  _ _ _ _ ____      / ____|/ ____|_ _| | | | | | | | _ \      | (___ | |  | |______| |__| | | | | |_) |     \___ \| |  | |______| __ | | | | _ <      ____) | |____ _| |_  | | | | |__| | |_) |     |_____/ \_____|_____| |_| |_|\____/|____/         '''  print(title)   if __name__ == '__main__':  while True:   welcome()   request = input('请输入URL、PMID、DOI或者论文标题:')   print('搜索中...')   downUrl = search_article(request)   if downUrl == '':    print('未找到相关论文,请重新搜索!')   else:    print('论文链接:%s'%downUrl)    print('下载中...')    pdf = download_article(downUrl)    with open('%s.pdf'%request, 'wb') as f:     f.write(pdf)    print('---下载完成---')   time.sleep(0.8)

关于使用Python怎么编写一个论文下载器问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI