一日一技:如何处理配置文件中的重复值?

开发 前端
在我们创建配置文件的时候,可能会出现一些值需要重复填写多次的问题。例如我最近写了一个可配置爬虫,只需要配置几条 XPath,就能够自动生成一个 Scrapy 爬虫。从而快速完成简单网站的爬取。

[[374508]]

在我们创建配置文件的时候,可能会出现一些值需要重复填写多次的问题。例如我最近写了一个可配置爬虫,只需要配置几条 XPath,就能够自动生成一个 Scrapy 爬虫。从而快速完成简单网站的爬取。

这个配置文件长这样:

  1. name: 某某网站爬虫 
  2. host: 'https://www.kingname.info' 
  3. headers:  
  4.  user-agent: xxx 
  5.   host: yyyy 
  6.   referer: zzz 
  7. rule
  8.   start_url: 'https://www.kingname.info' 
  9.   detail_url: //div[@class="xxx"]/a/@href 
  10.   next_page_xpath: //div[@class="next"]/@href 
  11.   ...其他配置参数... 

这个配置文件是使用 YAML 格式创建的。我们可以看到,最外层的host的值为https://www.kingname.info,而在rule里面,start_url的值也是这个网址。这样就重复了。这种重复的情况还有很多,例如列表页的翻页链接的 XPath 与正文页的翻页链接的 XPath 是一样的,多个类型可以具有相同的执行规则等等。

如果你使用 JSON 来作为配置文件的格式,那么确实你要重复写。但如果你使用 YAML 来作为配置文件的格式,那么你可以通过添加锚记(anchor)和别名(alias)的方式,实现一次填写,多次使用的效果。

我们先来看一个简单的例子:

  1. import yaml 
  2.  
  3. config = ''
  4. name: &name 青南 
  5. salary: 99999 
  6. other_name: *name 
  7. ''
  8. info = yaml.safe_load(config) 
  9. print(info) 

运行效果如下图所示:

可以看到,原本定义一个key-value类型的值,应该是key: value的形式,但是这里我写成key: &锚记名 value,于是,这个锚记名就相当于是一个变量名,就可以在其他地方引用。引用的时候,写作*锚记名。这有点像 C 语言中的获取变量的内存地址(&),然后显示指针的值(*)。锚记名可以 key 相同,也可以不同。

当然,除了简单的key-value,也可以在复杂的场景下使用,例如:

  1. import yaml 
  2.  
  3. config = ''
  4. article_xpath: &article 
  5.     title: //div[@class="title"]/text() 
  6.     detail: //div[@class="content"]/text() 
  7.     image:  
  8.         - //div/img[@class="xx"]/@href 
  9.         - //p/img[@class="yy"]/@href 
  10. about_xpath: 
  11.     summary: //div[@class="summary"]/text() 
  12. book_xpath: *article 
  13. ''
  14. info = yaml.safe_load(config) 

运行效果如下图所示:

这样一来,如果某一项会多次出现的配置发生了修改,我们只需要改一个地方,就能在多个地方同时自动生效,不用再一个一个手动修改了。既节省了时间又不容易出错。

本文转载自微信公众号「未闻Code」,可以通过以下二维码关注。转载本文请联系未闻Code公众号。

 

责任编辑:武晓燕 来源: 未闻Code
相关推荐

2022-03-12 20:38:14

网页Python测试

2021-10-15 21:08:31

PandasExcel对象

2022-06-28 09:31:44

LinuxmacOS系统

2020-12-11 06:30:00

工具分组DataFrame

2021-12-15 22:04:11

浏览器重复登录

2021-06-18 05:54:27

MongoDB数据

2023-10-28 12:14:35

爬虫JavaScriptObject

2021-04-27 22:15:02

Selenium浏览器爬虫

2021-05-08 19:33:51

移除字符零宽

2021-06-08 21:36:24

PyCharm爬虫Scrapy

2021-07-27 21:32:57

Python 延迟调用

2022-03-07 09:14:04

Selenium鼠标元素

2021-02-14 22:22:18

格式图片 HTTP

2024-01-29 00:45:36

跨域后端接口

2021-05-13 09:01:51

Cloud Flare浏览器网站

2023-10-29 09:16:49

代码安全命令

2021-04-05 14:47:55

Python多线程事件监控

2021-06-29 20:44:59

Linux Zip命令

2024-02-20 22:13:48

Python项目Java

2020-05-19 13:55:38

Python加密密码
点赞
收藏

51CTO技术栈公众号