信息组织和提取方法

信息标记的三种形式

信息的标记

  • 标记后的信息可形成信息组织结构,增加了信息的维度
  • 标记后的信息可用于通信、存储或展示
  • 标记的结构与信息一样具有重要价值
  • 标记后的信息更利于程序理解和运用

信息标记的三种形式:

XMLJSONYAML

  • XML eXtensible Markup Language
  • JSON JavaScript Object Notation
     "key":"value"
     "key":["value1","value2"]
     "key":{"subkey":"subvalue"}
  • YAML YAML Ain't Markup Language
    • 无类型键值对 key:value,缩进来表达所属关系
     name: 北京理工大学
     name:
          newName:北京理工大学
          oldName:延安自然科学院
\- 表达并列关系
    name:
    \- 北京理工大学
    \- 延安自然科学院
| 表达整块数据 \# 表示注释
text: | #学校介绍
北京理工大学创立于1940年,前身是。。。。。

三种信息标记形式的比较

XML实例

<person>
    <firstName>Tian</firstName>
    <lastName>Song</lastName>
    <address>
        <streetAddr>中关村南大街5号</streetAddr>
        <city>北京市</city>
        <zipcode>100081</zipcode>
    </address>
    <prof>Computer System</prof><prof>Security</prof>
</person>

JSON实例

{
    "firstName" : "Tian" ,
    "lastName"  : "Song" ,
    "address"   : {
                   "streetAddr" : "中关村南大街5号" , 
                   "city"       : "北京市" ,
                   "zipcode"    : "100081"
                  } ,
    "prof"      : [ "Computer System", "Security" ]
}

YAML实例

firstName : Tian
lastName  : Song
address   :
    streetAddr : 中关村南大街5号
    city       : 北京市
    zipcode    : 100081
prof :
- Computer System
- Security
比较

XML 最早的通用信息标记语言,可扩展性好,但繁琐。
JSON 信息有类型,适合程序处理(js),较XML简洁。
YAML 信息无类型,文本信息比例最高,可读性好

用途

XML Internet上的信息交互与传递。
JSON 移动应用云端和节点的信息通信,无注释。
YAML 各类系统的配置文件,有注释易读。

信息提取的一般方法

  • 方法一:完整解析信息的标记形式,再提取关键信息。
    XML JSON YAML
    需要标记解析器 例如:bs4库的标签树遍历
    优点:信息解析准确
    缺点:提取过程繁琐,速度慢。
  • 方法二:无视标记形式,直接搜索关键信息
    搜索
    对信息的文本查找函数即可。
    优点:提取过程简洁,速度较快
    缺点:提取结果准确性与信息内容相关。

融合方法:结合形式解析与搜索方法,提取关键信息

XML JSON YAML 搜索
需要标记解析器及文本查找函数。

实例

提取HTML中所有URL链接
思路:1)搜索到所有a标签
2)解析a标签格式,提取href后的链接内容。

from bs4 import BeautifulSoup
soup = BeautifulSoup(demo, "html.parser")
for link in soup.find_all('a'):
    print(link.get('href'))

基于bs4库的HTML内容查找方法

<>.find_all(name, attrs, recursive, string, **kwargs)
返回一个列表类型,存储查找的结果。
name:对标签名称的检索字符串。
attrs:对标签属性值的检索字符串,可标注属性检索。
recursive:是否对子孙全部检索,默认True。
string:<>..</>中字符串区域的检索字符串。

soup.find_all('a')
soup.find_all(['a', 'b'])
import re
for tag in soup.find_all(re.compile('b')):
    print(tag.name)
soup.find_all('p', 'course')
soup.find_all(id='link1')
import re
soup.find_all(id=re.cmpile('link'))
soup.find_all('a', recursive=False)
soup.find_all(string = "Basic Python")
import re
soup.find_all(string = re.compile("python"))

<tag>(..) 等价于<tag>.find_all(..)
soup(..) 等价于 soup.find_all(..)

扩展方法

方法 说明
<>.find() 搜索且只返回一个结果,字符串类型,同.find_all()参数
<>.find_parents() 在先辈节点中搜索,返回列表类型,同.find_all()参数
<>.find_parent() 在先辈节点中返回一个结果,字符串类型,同.find()参数
<>.find_next_siblings() 在后续平行节点中搜索,返回列表类型,同.find_all()参数
<>.find_next_sibling() 在后续平行节点中返回一个结果,字符串类型,同.find()参数
<>.find_previous)siblings() 在前序平行节点中搜索,返回列表类型,同.find_all()参数
<>.find_previous_sibling() 在前序平行节点中返回一个结果,字符串类型,同.find()参数
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容