此处有几种选择可以达到目的:

(1)官网上匹配筛选条件(注:匹配快速,但是下载下来的数量受到限制,每次只能下载10000条数据,甚至更少。)

可以看到,我需要的数据是有三十多万条,但是每次只能下载10000条,那我岂不是要手动n次。。很明显,在大批量下载文献的情况下,官网不是很友好。

(2)R语言有个R包,叫做easyPubMed,这里我也给大家贴上学习指南(https://cran.r-project.org/web/packages/easyPubMed/vignettes/getting_started_with_easyPubMed.html)

由于我不喜欢用R写代码,所以我写一半还是换了Python,熟练R的小伙伴可以自行根据指南走通需求。

(3)重量级库来了,Python自带的Bio包中的Entrez检索库,简直就是我的救星,以下是我的代码:

注:Entrez在Bio包中,Bio的安装请移步 https://www.cnblogs.com/xiaolan-Lin/p/14023147.html

1 import numpy as np
2 from Bio import Medline, Entrez # 一般是通过BioPython的Bio.Entrez模块访问Entrez
3 from collections import Counter
4
5 Entrez.email = “(此处写你自己在官网注册的邮箱账号)” # 应用自己的账号访问NCBI数据库
6
7 # 此处需将服务器协议指定为1.0,否则会出现报错。http.client.IncompleteRead: IncompleteRead(0 bytes read)
8 # 服务器http协议1.0,而python的是1.1,解决办法就是指定客户端http协议版本
9 import http.client
10 http.client.HTTPConnection._http_vsn = 10
11 http.client.HTTPConnection._http_vsn_str = ‘HTTP/1.0’
12
13 “”"
14 Entrez 是一个检索系统,可以用其访问NCBI数据库,比如说PubMed,GenBank,GEO等。
15 获得有关 global PBDE 的所有文献的PubMed IDs
16 “”"
17 # handle_0 = Entrez.esearch(db=“pubmed”, term=“drug therapy[Subheading] AND adverse effects[Subheading] AND humans[MeSH Terms]”, retmax=306431)
18 handle_0 = Entrez.esearch(db=“pubmed”, term=“drug therapy[MeSH Subheading] AND adverse effects[MeSH Subheading] AND humans[MeSH Terms] AND (2000/01/01[Date - Publication] : 2021/12/31[Date - Publication])”,
19 ptyp=“Review”, usehistory=“y”, retmax=306431)
20 record = Entrez.read(handle_0) # 获取检索条件的所有文献
21 idlist = record[“IdList”] # 提取出文献id
22 print (“Total: “, record[“Count”])
23 No_Papers = len(idlist) # 共306431篇文献 2000-01-01:2021-12-31
24 webenv = record[‘WebEnv’]
25 query_key = record[‘QueryKey’]
26
27 total = No_Papers
28 step = 1300
29 print(“Result items:”, total)
30 with open(”./Data_PubMed/PBDE1.txt”, ‘w’) as f:
31 for start in range(0, total, step):
32 print(“Download record %i to %i” % (start + 1, int(start + step)))
33 handle_1 = Entrez.efetch(db=“pubmed”, retstart=start, rettype=“medline”, retmode=“text”,
34 retmax=step, webenv=webenv, query_key=query_key) # 获取上述所有文献的PubMed IDs
35 records = Medline.parse(handle_1)
36 records = list(records) # 将迭代器转换至列表(list)
37 for index in np.arange(len(records)):
38 id = records[index].get(“PMID”, “?”)
39 title = records[index].get(“TI”, “?”)
40 title = title.replace(’[’, ‘’).replace(’].’, ‘’) # 若提取的标题出现[].符号,则去除
41 abstract = records[index].get(“AB”, “?”)
42 f.write(id)
43 f.write("\n")
44 f.write(title)
45 f.write("\n")
46 f.write(abstract)
47 f.write("\n")
话不多说,结果跑出来了我真的很快乐~

最后的结果是存放在txt文件中,大伙儿根据自己的需求改变代码所需字段啊。

现在我来解释一下,我贴上的这串代码的实现原理,首先是通过Entrez检索到符合我筛选条件的文献,里边的限制条件包括了几个词汇匹配以及时间限制,时间我限制在了2000年1月1日到2021年的12月31日(这里的时间我选用的是Date - Publication,时间选取Date - Completion、Date - Modification还是Date - Publication其实还是有争议的,大家自行考虑选取)。

Entrez.esearch的作用就是用来检索的,里边的参数db指向你要检索的数据库,代码中的注释也写了,Entrez作为一个接口检索,除了能够检索PubMed中的文献,也能去到别的数据库检索文献;term是写你的筛选语句,注意你写的检索语句不能带有引号,单引号也不行,否则会检索不到,如果不知道检索语句怎么写,或者是不知道字段是否被定义,可以在官网的检索那里https://pubmed.ncbi.nlm.nih.gov/advanced/选择字段输入内容自动生成query,但是生成的语句是不太智能的,会有很多括号是你不需要的,自己写代码的时候要适当去掉;ptyp我这里用的是Review,usehistory是y,意思是后边我的检索要记住这个语句,根据历史查询来检索;retmax如果不进行设置的话,默认给你的最大数据量好像是只有1000,我要的检索内容是超过这个值的,因此我需要自定义检索的数量。

Entrez.read是对Entrez.esearch检索到的内容进行读取,里边包含了9种元素,我们主要是想从中得到文献的id号,只有拿到了文献的id号,我们后面进行摘要的提取才能准确定位。

最后是循环当中步长的设置,这里就要根据自己的需求来定义了,包括内容的提取,因为我只需要PMID、标题(TI)、摘要(AB),所以我就没有加载别的内容进来,这里也有一点要注意,标题下载下来是大部分带有[ ].的,方便操作我直接就在下载的时候给去除了,这也是上面replace代码的由来。

附上我参考的链接,如果我这篇文章解决不了你的问题,那么希望下面的渠道能够帮助到你
学习视频资料:http://www.makeru.com.cn/live/1392_1164.html?s=143793

Python:利用Entrez库筛选下载PubMed文献摘要相关推荐

  1. python画笑脸-python 利用turtle库绘制笑脸和哭脸的例子

    我就废话不多说了,直接上代码吧! import turtle turtle.pensize(5) turtle.pencolor("yellow") turtle.fillcolo ...

  2. python turtle画彩虹-Python利用turtle库绘制彩虹代码示例_天津SEO

    天津SEO RGB模型:光的三原色,共同决定色相 HSB/HSV模型:H色彩,S深浅,B饱和度,H决定色相 需要将HSB模型转换为RGB模型 代码示例: #-*- coding:utf-8 –*- f ...

  3. python画图代码彩虹-Python利用turtle库绘制彩虹代码示例

    语言:Python IDE:Python.IDE 需求 做出彩虹效果 颜色空间 RGB模型:光的三原色,共同决定色相 HSB/HSV模型:H色彩,S深浅,B饱和度,H决定色相 需要将HSB模型转换为R ...

  4. py之textgenrnn:Python利用textgenrnn库实现训练文本生成网络

    py之textgenrnn:Python利用textgenrnn库实现训练文本生成网络 目录 输出结果 实现代码 输出结果 实现代码 #textgenrnn:利用textgenrnn实现训练文本生成网 ...

  5. python利用datetime库实现通过身份证号码判断年龄、男女,并输出生日

    python利用datetime库实现通过身份证号码判断年龄.男女,并输出生日 实现很简单,直接上代码 import datetimeID=str(input("输入身份证号码") ...

  6. python利用dominate库生成静态网页

    HTML报告:python利用dominate库生成静态网页 dominate 简介 一个生成页面的简单例子 标记的属性 如何生成复杂的文档结构 访问内容和属性 渲染 上下文管理器 装饰器 创建文档 ...

  7. Python利用turtle库绘图大熊猫

    Python利用turtle库绘图大熊猫 卡通大熊猫的详细代码 由代码绘制的熊猫宝宝 Turtle库是Python语言中一个很流行的绘制图像的函数库,想象一个小乌龟,在一个横轴为x.纵轴为y的坐标系原 ...

  8. python画笑脸图案-python 利用turtle库绘制笑脸和哭脸的例子

    我就废话不多说了,直接上代码吧! import turtle turtle.pensize(5) turtle.pencolor("yellow") turtle.fillcolo ...

  9. python利用sympy库对某个函数求导,numpy库使用该求导结果计算的程序

    ** python利用sympy库对某个函数求导,numpy库使用该求导结果计算的程序 ** 在python数据处理过程中,我们经常会遇见这样一种情况.需要对一个函数表达式求偏导,并将具体数值代入导数 ...

  10. Python利用PyPDF2库获取PDF文件总页码

    Python中可以利用PyPDF2库来获取该pdf文件的总页码,可以根据下面的方法一步步进行下去: 1.首先,要安装PyPDF2库,利用以下命令即可: pip install PyPDF2 2.接着, ...

最新文章

  1. js获取当前页面的参数,带完善~~~
  2. 算法--06谷歌面试:字符串中第一个只出现一次的字符(Java实现)
  3. 【深度学习】谷歌最新提出无需卷积、注意力 ,纯MLP构成的视觉架构!网友:MLP is All You Need ?...
  4. 经典C语言程序100例之一
  5. LInux--进程间通信
  6. linux-实时查看mysql中的日志文件
  7. 辗转相除求最大公约数最小公倍数 扩展欧几里得算法
  8. 【事件驱动】【数码管识别】 一台电脑能接多少台USB设备
  9. 阶段3 2.Spring_08.面向切面编程 AOP_3 spring基于XML的AOP-编写必要的代码
  10. Adobe Dreamweaver CS6已停止工作的解决办法
  11. 初生牛犊不怕虎,管他呢! 干就是了。
  12. java工作日志,如何写工作日志
  13. 80后十大烦恼的特征
  14. 易建联惨遭雄鹿霸王硬上弓!!!
  15. 图片动漫化 - 面部 - AnimeGAN
  16. 实体商家也能玩转月活10亿的微信小程序生态
  17. SQLSERVER时间函数
  18. 新概念英语(1-99)Ow!
  19. python汉诺塔问题输入层数输出整个移动流程_python 实现汉诺塔游戏
  20. 生孩子是要顺产还是剖腹产

热门文章

  1. 中国研修网计算机培训心得,网络研修培训心得体会(精选7篇)
  2. 命令行CMD计算文件HASH值
  3. 物联网终端安全系列(之四) -- 终端安全方案之SIM卡篇
  4. 树莓派进阶之路 (031) -字符问题(1) - GBK汉字编码表(转)
  5. Opencv 轮廓提取
  6. Ubuntu压缩视频
  7. 每日工作记录——状态机的编码选择
  8. https免费泛域名证书申请
  9. Android能装到电脑上吗,怎么在电脑上装安卓系统
  10. Win10 提示账户名与安全标识间无任何映射完成