第六章 正则,BeautifulSoup,xpath

1.正则

1.1 提取字符串

import re
#提取字符串
#替换
#搜索

info="姓名:bobby 1987 生日:1987年10月1日 本科:2005年9月1日"
print(re.findall("\d{4}",info))
result=re.match(".*生日.*?(\d{4}).*本科:(\d{4})",info)

#match方法是从字符串的最开始匹配的 .*贪婪匹配 .*?非贪婪匹配 打括号分组
print(result.group(1))
print(result.group(2))

在这里插入图片描述

1.2 替换

import re
#提取字符串
#替换
#搜索

info="姓名:bobby 1987 生日:1987年10月1日 本科:2005年9月1日"
#提取字符串
print(re.findall("\d{4}",info))
result=re.match(".*生日.*?(\d{4}).*本科:(\d{4})",info)

#match方法是从字符串的最开始匹配的 .*贪婪匹配 .*?非贪婪匹配 打括号分组
print(result.group(1))
print(result.group(2))

#替换
res=re.sub("\d{4}","2019",info)
res1=re.sub("本科:2005年9月1日","*************",info)
print("res="+res)
print("res1="+res1)

在这里插入图片描述

1.3 搜索

import re
#提取字符串
#替换
#搜索

info="姓名:bobby 1987 生日:1987年10月1日 本科:2005年9月1日"
#提取字符串
print(re.findall("\d{4}",info))
result=re.match(".*生日.*?(\d{4}).*本科:(\d{4})",info)

#match方法是从字符串的最开始匹配的 .*贪婪匹配 .*?非贪婪匹配 打括号分组
print(result.group(1))
print(result.group(2))

#替换
res=re.sub("\d{4}","2019",info)
res1=re.sub("本科:2005年9月1日","*************",info)
print("res="+res)
print("res1="+res1)

#搜索
name="my name is bobby"

print(re.search("bobby",name))
print(re.search("bobby",name).group())
#re.IGNORECASE忽略大小写
name1="my name is Bobby"
print(re.search("bobby",name1,re.IGNORECASE).group())

在这里插入图片描述

#DOTALL模式,即使换行符也可以继续读
print(re.match(".*bobby",name2,re.DOTALL).group())

在这里插入图片描述

2. beautifulsoup

通过这个库来知道将Html页面下载下来之后我们如何去解析html里面的元素,如何从这些元素中提取出我们想要的一些值,下载一定要下载beautifulsoup4。

2.1 各种解析器

在这里插入图片描述

2.2 提取方式

bs=BeautifulSoup(html,“html.parser”)
提取方式,首先定位到这个元素,所有操作都是基于bs这个对象进行的,如果要取它的title,可以直接写bs.title。点取属性,返回的是BeautifulSoup里面的一个类。
title_tag=bs.title
在类上就可以进行取值,在类上有一个属性string,可以用它直接获取内容。
print(title_tag.string)

from bs4 import BeautifulSoup
html="""
<!DOCTYPE html>
<html lang="en">
<head>
    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/4.3.1/css/bootstrap.min.css">
    <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>


    <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->
    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css">
    <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>

    <meta charset="UTF-8">
    <title>CHINA IN HISTORY</title>

    <style type="text/css">
        .carousel-caption {
            background: #000000;/*设置容器背景颜色为黑色*/
            color: #ffffff;/*设置文本颜色为白色*/
            opacity: 0.7;/*设置透明度为 70%*/
            filter:alpha(opacity=70);/*设置透明度兼容 ie8 及以下版本*/
            font-family: 宋体;/*设置字体*/
            font-size: 18px;
            width: 100%;/*设置容器宽度*/
            left: 0px;/*设置容器左边缘位置*/
            bottom: 0px;/*设置容器下边缘位置*/
        }
        body{
            background-color: whitesmoke;
        }

    </style>

</head>
<body>
<div class="container-fluid" style="background-color: #ffffff"><img src="image/Logo1.png" width="480" height="140"></div>
<div class="container-fluid" id="asd" style="background-color:#eaeaea;opacity: 80%">
    <div class="container">
        <ul class="nav nav-pills">
            <li ><a href="#" class="text-dark">首页</a></li>
            <li><a href="#" class="text-dark">民族英雄</a></li>
            <li><a href="#" class="text-dark">历史机遇</a></li>
            <li data-toggle="modal" data-target="#myModal"><a href="#" class="text-dark">注册</a></li>
            <li data-toggle="modal" data-target="#myModal2"><a href="#" class="text-dark">登录</a></li>
            <li>
                <input type="text" style="border-radius: 2px;width: 300px;margin-top: 7px;margin-left: 340px">
                <button style="border-radius: 2px">
                    <span class="glyphicon glyphicon-search"></span>搜索
                </button>
            </li>
        </ul>
    </div>
</div>

<div class="container mt-3">
    <div class="row ">
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <img src="image/img_1.png" class="card-img-top" alt="...">
            <div >
                <h5 class="card-title" style="font-size: 20px">仕女图是中国历史文化的璀璨一角</h5>
                <p class="card-text">仕女图亦称“仕女画”,是以中国封建社会宫女为题材的绘画艺术作品。仕女图最早出现于魏晋南北朝,繁荣兴盛于唐宋时期,元代因社会动荡政治冲突逐渐衰退,明清时期再次兴盛,并出现创作的鼎盛时代。魏晋以来,有一批历代名家的《仕女图》,将女性温柔婉约、仪态容貌描绘得栩栩如生、活灵活现,让人拍手叫绝,叹为观止!</p>
            </div>

            <blockquote class="blockquote mb-0 card-body border mt-2">
                <p>中国艺术文化重形象思维,重传神,重意境。无论哪种笔法,都晕染着真善美。</p>
                <footer class="blockquote-footer">
                    艺术体现中国人的观念,也温润着中国人的心性。
                </footer>
            </blockquote>
            <br/><br/>
            <div class="card bg-light mb-3 ml-4 border" style="max-width: 60rem;">
                <div class="card-header" >近期文章</div>
                <div class="card-body">
                    <p class="card-text">
                        <a href="https://yizhongtian.blog.caixin.com/archives/255274" class="text-blue">易中天:中华文明以唐宋为高峰,元明清走了下坡路</a>
                        <br/><br/>
                        <a href="http://www.qulishi.com/article/202203/595802.html" class="text-blue">历史上曹操要血洗徐州的原因是什么?与曹嵩有何关系</a>
                        <br/><br/>
                        <a href="https://world.gmw.cn/2020-11/12/content_34363873.htm"class="text-blue">中国加快国防和军队现代化步伐</a>
                        <br/><br/>
                        <a href="https://www.sohu.com/a/530450019_265827" class="text-blue">人民日报看吉林:坚定必胜决心 尽快控制疫情</a>
                    </p>
                </div>

            </div>


        </div>
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <img src="image/img_2.png" class="card-img-top" alt="...">
            <div class="card-body">
                <h5 class="card-title" style="font-size: 20px">世人都知于谦石灰吟,却少知这位清官也是一位显赫的民族战斗英雄</h5>
                <p class="card-text">于谦远比我们知道的丰富很多,他所在的时代,宦官坏国,然而王振却依旧动不得于谦,每当权势滔天的王振想解决于谦,他的命令总是无法执行,得到的回应总是警告:你最好别动这个人。并非天子保于谦,而是对于于谦,识者无不敬服!在明朝最困难的时候,于谦运筹帷幄,杀伐果断,力挽狂澜,体现出超人的军事能力,他死后,锦衣卫搜查其家落泪,太后为他水米不进。英雄陨落,悲矣!</p>
                <p class="card-text"><small class="text-muted"></small></p>
                <blockquote class="blockquote mb-0  text-center p-3" style="background-color: #f3f5f5">
                    <p>于谦为官兢兢业业,为百姓鞠躬尽瘁,但真正让他大施拳脚的时刻是土木堡之变。</p>
                    <p>于谦深知国不可一日无君,在皇帝沦为阶下囚,太子尚为襁褓,大明朝面临大厦将倾局面时,冒天下之大不韪,奏请郕王为帝,用于稳定局面。</p>
                    <p>有人说,中国人被一群英雄保护得好好的。我想说是的,中国从来不缺英雄,并且中国民众追随英雄。</p>
                </blockquote>
            </div>
        </div>
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <div class="card text-center " style="background-color: #ffffff">
                <div class="card-body">
                    <h5 class="card-title">掠影惊鸿</h5>
                    <p class="card-text" style="font-size: 15px">历史中的中国,就如一个男人成长。自负,鞭策,灾难,荣光壹壹经历。
                        近代史惨痛,可更早的历史中国是站在最高点的国邦。威震四海,不可撼动。
                        臣服,交好。是其他国家的选择。<br/><br/>
                        可是1900年中国跌倒了,倒了很久,以至于动荡战乱,老一辈记忆刻下不可磨灭的悲痛。
                        中国当然会再站起来,在00后出生的50年前,毛泽东在天安门一锤定音。
                        新时代青年大多知道祖国经历民族耻辱,民族光辉事件的皮毛,却少有人去细看中国为什么能崛起,
                        历史中的中国做过哪些挣扎,又有哪些冲突。<br/><br/>
                        我始终认为,中国的进步,是由无数个在领导位置、沉稳决策的智者与善良爱国、执行正确方针的民众打造的。
                        前者甚至比后者更重要。
                        这个网页就是用来稍稍记录历史中的中国如何走向今日繁华。更祝愿我华夏千秋业新篇永续!</p>
                    <p class="card-text"><small class="text-muted"></small></p>
                </div>
            </div>
            <div class="card mt-5">
                <img src="image/img_3.jpg" class="card-img-top" alt="...">
            </div>
        </div>
    </div>
    <div class="row">
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4 ">
            <div class="card bg-light text-white border">
                <div class="card-header" style="background-color: #c7cece">快捷通道</div>
                <div class="card-body">
                    <p class="card-text">
                    <div class="row">
                        <div class="col-md-4"><a href="http://www.hnmuseum.com/"><img src="image/hunan.png" width="90" height="90"></a> </div>
                        <div class="col-md-4"><a href="http://www.njmuseum.com/zh"><img src="image/nanjing.png" width="90" height="90"></a> </div>
                        <div class="col-md-4"><a href="https://www.xabwy.com/"><img src="image/xian.png" width="90" height="90"></a> </div>
                    </div>
                    <div class="row">
                        <div class="col-md-4 mt-2"><a href="http://www.scmuseum.cn/"><img src="image/sichuan.png" width="90" height="90"></a> </div>
                        <div class="col-md-4 mt-2"><a href="https://www.zhejiangmuseum.com/"><img src="image/zhejiang.png" width="90" height="90"></a> </div>
                        <div class="col-md-4 mt-2"><a href="https://www.shanghaimuseum.net/mu/frontend/pg/index"><img src="image/shanghai.png" width="90" height="90"></a> </div>
                    </div>

                    </p>
                </div>
            </div>
        </div>

        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4 ">
            <video controls src="image/video1.mp4"width="100%" style="top: 100px;border: 0px solid;solid-color: #1b1e21"></video>
        </div>
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <div class="card p-3 text-right">
                <blockquote class="blockquote mb-0">
                    <p style="font-size: 20px;text-align: center">如果你要和平,请准备战争。</p>
                    <footer class="blockquote-footer">

                        古罗马著名军事著作家 韦格蒂乌斯

                    </footer>
                </blockquote>
            </div>

            <div class="card p-3 text-right mt-5">
                <blockquote class="blockquote mb-0">
                    <p style="font-size: 20px;text-align: center">和平时代,军队还是应该保持锐气,万不可得"和平病"。</p>
                    <footer class="blockquote-footer">

                        电视剧《王牌部落》

                    </footer>
                </blockquote>
            </div>
        </div>
    </div>

</div>
<footer style="text-align: center">
    <div class="container-fluid" style="height:300px ;background-color: #cdc3be">
        <div class="mt-5" style="text-align: center">
            <img src="image/Logo1.png" height="100" width="320">
            <p>1234567 | 7654321</p>
            <p>jsdxrjxy@163.com</p>
            <p>地址:湖南省张家界市子午路 | 版权所有:吉首大学软件服务外包学院</p>
        </div>
    </div>
</footer>
</body>
</html>
"""

bs=BeautifulSoup(html,"html.parser")
title_tag=bs.title
print(title_tag.string)

在这里插入图片描述
取div时会发现如果用点属性,只会取到第一个满足条件的div,所以上述方法适用的是像title这样只有一个的属性,像div这样有许多个的,就要用另外的方法——find。

2.3 find方法

bs=BeautifulSoup(html,“html.parser”)

2.3.1 find

bs.find(“div”) 也只能找到第一个符合条件的div

2.3.2 find_all

bs.find_all(“div”) 返回所有的div
可以用for循环来输出

div_tags=bs.find_all("div")

for tag in div_tags:
    print(tag.string)

很多时候我们需要进一步定位,比如id来定位。

2.3.3 通过id和类型精确定位

div_tag1=bs.find("div",id="aaa")
print(div_tag1)

在这里插入图片描述

2.3.3.1 通过符合正则表达式的id定位

将上面的id="aaa"改为id="aaa-9999"方便演示

div_tag1=bs.find("div",id=re.compile("aaa-\d+"))
print(div_tag1)

在这里插入图片描述

2.3.4 通过内容查找元素

在这里插入图片描述
但是目前看作用不大,string后面也可以用正则
在这里插入图片描述

2.4 获取父子节点和兄弟节点

2.4.1 获取父子节点

2.4.1.1 contents属性,提取一级子元素
bs=BeautifulSoup(html,"html.parser")
div_tag2=bs.find("div",re.compile("bbb-\d+"))
childrens=div_tag2.contents
for child in childrens:
	print(child.name)

在这里插入图片描述
None是因为程序把\n解析了,所以我们要加个判断

bs=BeautifulSoup(html,"html.parser")
div_tag1=bs.find("div",re.compile("bbb-\d+"))
childrens=div_tag1.contents
for child in childrens:
    if child.name:
        print(child.name)

在这里插入图片描述

2.4.1.2 descendants属性,提取所有级子元素
bs=BeautifulSoup(html,"html.parser")
div_tag2=bs.find("div",re.compile("bbb-\d+"))
childrens=div_tag2.descendants
for child in childrens:
	if child.name:
		print(child.name)
2.4.1.3 获取第一个父元素

注意:如果find()写find(“p”,class=“name”),class是关键词,冲突,所以要换个写法:
bs.find(“p”,{“class”:“name”})

bs=BeautifulSoup(html,"html.parser")
parent=bs.find("h5",{"class":"card-title"}).parent
print(parent)

在这里插入图片描述

2.4.1.4 获取所有父元素
bs=BeautifulSoup(html,"html.parser")
parents=bs.find("h5",{"class":"cart-title"})
for parent in parents:
	print(parent.name)

在这里插入图片描述

2.4.2 获取兄弟节点

2.4.2.1 获取之后的兄弟元素——next_siblings
bs=BeautifulSoup(html,"html.parser")
next_siblings=bs.find("p",string=re.compile("于谦深知.*")).next_siblings
for sibling in next_siblings:
	print(sibling.string)

原码参照:
在这里插入图片描述
代码运行结果:
在这里插入图片描述
可以看见后面的兄弟元素内容提取出来了,前面的没有。那么如何提取前面的兄弟元素呢?

2.4.2.2 获取之前的兄弟元素——previous_siblings
bs=BeautifulSoup(html,"html.parser")
privious_siblings=bs.find("p",string=re.compile("于谦深知.*")).previous_siblings
for sibling in privious_siblings:
    print(sibling.string)

源码参考:
在这里插入图片描述
代码运行结果:
在这里插入图片描述
siblings用单数sibling可以取到前面一个兄弟元素,但是会受换行符的影响,换行符也会被当做兄弟元素

2.4.3 多值属性

tag=bs.find("p",string=re.compile("于谦为官.*"))
print(tag["class"])
print(tag.get("class"))

源码参考:
在这里插入图片描述
代码运行结果:
在这里插入图片描述
多值属性返回列表
单值属性返回字符串

3. xpath基本语法

3.1 xpath简介

在这里插入图片描述
在这里插入图片描述

3.2 xpath术语

在这里插入图片描述

3.3 xpath语法

3.3.1 xpath基础表达式

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
利用浏览器自动生成xpath路径
在这里插入图片描述
把xpath复制到编译器内时,注意双引号里面的双引号得换成单引号

3.3.2 提取标签节点

from scrapy import Selector
html="""
<!DOCTYPE html>
<html lang="en">
<head>
    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/4.3.1/css/bootstrap.min.css">
    <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>


    <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->
    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css">
    <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>

    <meta charset="UTF-8">
    <title>CHINA IN HISTORY</title>

    <style type="text/css">
        .carousel-caption {
            background: #000000;/*设置容器背景颜色为黑色*/
            color: #ffffff;/*设置文本颜色为白色*/
            opacity: 0.7;/*设置透明度为 70%*/
            filter:alpha(opacity=70);/*设置透明度兼容 ie8 及以下版本*/
            font-family: 宋体;/*设置字体*/
            font-size: 18px;
            width: 100%;/*设置容器宽度*/
            left: 0px;/*设置容器左边缘位置*/
            bottom: 0px;/*设置容器下边缘位置*/
        }
        body{
            background-color: whitesmoke;
        }

    </style>

</head>
<body>
<div class="container-fluid" style="background-color: #ffffff"><img src="image/Logo1.png" width="480" height="140"></div>
<div class="container-fluid" id="asd" style="background-color:#eaeaea;opacity: 80%">
    <div class="container">
        <ul class="nav nav-pills">
            <li ><a href="#" class="text-dark">首页</a></li>
            <li><a href="#" class="text-dark">民族英雄</a></li>
            <li><a href="#" class="text-dark">历史机遇</a></li>
            <li data-toggle="modal" data-target="#myModal"><a href="#" class="text-dark">注册</a></li>
            <li data-toggle="modal" data-target="#myModal2"><a href="#" class="text-dark">登录</a></li>
            <li>
                <input type="text" style="border-radius: 2px;width: 300px;margin-top: 7px;margin-left: 340px">
                <button style="border-radius: 2px">
                    <span class="glyphicon glyphicon-search"></span>搜索
                </button>
            </li>
        </ul>
    </div>
</div>

<div class="container mt-3">
    <div class="row ">
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <img src="image/img_1.png" class="card-img-top" alt="...">
            <div id="aaa-9999">
                <h5 class="card-title" style="font-size: 20px">仕女图是中国历史文化的璀璨一角</h5>
                <p class="card-text">仕女图亦称“仕女画”,是以中国封建社会宫女为题材的绘画艺术作品。仕女图最早出现于魏晋南北朝,繁荣兴盛于唐宋时期,元代因社会动荡政治冲突逐渐衰退,明清时期再次兴盛,并出现创作的鼎盛时代。魏晋以来,有一批历代名家的《仕女图》,将女性温柔婉约、仪态容貌描绘得栩栩如生、活灵活现,让人拍手叫绝,叹为观止!</p>
            </div>

            <blockquote class="blockquote mb-0 card-body border mt-2">
                <p>中国艺术文化重形象思维,重传神,重意境。无论哪种笔法,都晕染着真善美。</p>
                <footer class="blockquote-footer">
                    艺术体现中国人的观念,也温润着中国人的心性。
                </footer>
            </blockquote>
            <br/><br/>
            <div class="card bg-light mb-3 ml-4 border" style="max-width: 60rem;">
                <div class="card-header" >近期文章</div>
                <div class="card-body">
                    <p class="card-text">
                        <a href="https://yizhongtian.blog.caixin.com/archives/255274" class="text-blue">易中天:中华文明以唐宋为高峰,元明清走了下坡路</a>
                        <br/><br/>
                        <a href="http://www.qulishi.com/article/202203/595802.html" class="text-blue">历史上曹操要血洗徐州的原因是什么?与曹嵩有何关系</a>
                        <br/><br/>
                        <a href="https://world.gmw.cn/2020-11/12/content_34363873.htm"class="text-blue">中国加快国防和军队现代化步伐</a>
                        <br/><br/>
                        <a href="https://www.sohu.com/a/530450019_265827" class="text-blue">人民日报看吉林:坚定必胜决心 尽快控制疫情</a>
                    </p>
                </div>

            </div>


        </div>
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <img src="image/img_2.png" class="card-img-top" alt="...">
            <div class="card-body" id="bbb-9999">
                <h5 class="card-title" style="font-size: 20px">世人都知于谦石灰吟,却少知这位清官也是一位显赫的民族战斗英雄</h5>
                <p class="card-text">于谦远比我们知道的丰富很多,他所在的时代,宦官坏国,然而王振却依旧动不得于谦,每当权势滔天的王振想解决于谦,他的命令总是无法执行,得到的回应总是警告:你最好别动这个人。并非天子保于谦,而是对于于谦,识者无不敬服!在明朝最困难的时候,于谦运筹帷幄,杀伐果断,力挽狂澜,体现出超人的军事能力,他死后,锦衣卫搜查其家落泪,太后为他水米不进。英雄陨落,悲矣!</p>
                <p class="card-text"><small class="text-muted"></small></p>
                <blockquote class="blockquote mb-0  text-center p-3" style="background-color: #f3f5f5">
                    <p class="yuqian0 yuqian1">于谦为官兢兢业业,为百姓鞠躬尽瘁,但真正让他大施拳脚的时刻是土木堡之变。</p>
                    <p>于谦深知国不可一日无君,在皇帝沦为阶下囚,太子尚为襁褓,大明朝面临大厦将倾局面时,冒天下之大不韪,奏请郕王为帝,用于稳定局面。</p>
                    <p>有人说,中国人被一群英雄保护得好好的。我想说是的,中国从来不缺英雄,并且中国民众追随英雄。</p>
                </blockquote>
            </div>
        </div>
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <div class="card text-center " style="background-color: #ffffff">
                <div class="card-body">
                    <h5 class="card-title">掠影惊鸿</h5>
                    <p class="card-text" style="font-size: 15px">历史中的中国,就如一个男人成长。自负,鞭策,灾难,荣光壹壹经历。
                        近代史惨痛,可更早的历史中国是站在最高点的国邦。威震四海,不可撼动。
                        臣服,交好。是其他国家的选择。<br/><br/>
                        可是1900年中国跌倒了,倒了很久,以至于动荡战乱,老一辈记忆刻下不可磨灭的悲痛。
                        中国当然会再站起来,在00后出生的50年前,毛泽东在天安门一锤定音。
                        新时代青年大多知道祖国经历民族耻辱,民族光辉事件的皮毛,却少有人去细看中国为什么能崛起,
                        历史中的中国做过哪些挣扎,又有哪些冲突。<br/><br/>
                        我始终认为,中国的进步,是由无数个在领导位置、沉稳决策的智者与善良爱国、执行正确方针的民众打造的。
                        前者甚至比后者更重要。
                        这个网页就是用来稍稍记录历史中的中国如何走向今日繁华。更祝愿我华夏千秋业新篇永续!</p>
                    <p class="card-text"><small class="text-muted"></small></p>
                </div>
            </div>
            <div class="card mt-5">
                <img src="image/img_3.jpg" class="card-img-top" alt="...">
            </div>
        </div>
    </div>
    <div class="row">
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4 ">
            <div class="card bg-light text-white border">
                <div class="card-header" style="background-color: #c7cece">快捷通道</div>
                <div class="card-body">
                    <p class="card-text">
                    <div class="row">
                        <div class="col-md-4"><a href="http://www.hnmuseum.com/"><img src="image/hunan.png" width="90" height="90"></a> </div>
                        <div class="col-md-4"><a href="http://www.njmuseum.com/zh"><img src="image/nanjing.png" width="90" height="90"></a> </div>
                        <div class="col-md-4"><a href="https://www.xabwy.com/"><img src="image/xian.png" width="90" height="90"></a> </div>
                    </div>
                    <div class="row">
                        <div class="col-md-4 mt-2"><a href="http://www.scmuseum.cn/"><img src="image/sichuan.png" width="90" height="90"></a> </div>
                        <div class="col-md-4 mt-2"><a href="https://www.zhejiangmuseum.com/"><img src="image/zhejiang.png" width="90" height="90"></a> </div>
                        <div class="col-md-4 mt-2"><a href="https://www.shanghaimuseum.net/mu/frontend/pg/index"><img src="image/shanghai.png" width="90" height="90"></a> </div>
                    </div>

                    </p>
                </div>
            </div>
        </div>

        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4 ">
            <video controls src="image/video1.mp4"width="100%" style="top: 100px;border: 0px solid;solid-color: #1b1e21"></video>
        </div>
        <div class="col-lg-4 col-sm-4 col-md-4 col-xl-4">
            <div class="card p-3 text-right">
                <blockquote class="blockquote mb-0">
                    <p style="font-size: 20px;text-align: center">如果你要和平,请准备战争。</p>
                    <footer class="blockquote-footer">

                        古罗马著名军事著作家 韦格蒂乌斯

                    </footer>
                </blockquote>
            </div>

            <div class="card p-3 text-right mt-5">
                <blockquote class="blockquote mb-0">
                    <p style="font-size: 20px;text-align: center">和平时代,军队还是应该保持锐气,万不可得"和平病"。</p>
                    <footer class="blockquote-footer">

                        电视剧《王牌部落》

                    </footer>
                </blockquote>
            </div>
        </div>
    </div>

</div>
<footer style="text-align: center">
    <div class="container-fluid" style="height:300px ;background-color: #cdc3be">
        <div class="mt-5" style="text-align: center">
            <img src="image/Logo1.png" height="100" width="320">
            <p>1234567 | 7654321</p>
            <p>jsdxrjxy@163.com</p>
            <p>地址:湖南省张家界市子午路 | 版权所有:吉首大学软件服务外包学院</p>
        </div>
    </div>
</footer>
</body>
</html>
"""
sel=Selector(text=html)
tag=sel.xpath("//*[@id="bbb-9999"]/p[1]")
print(tag)
print(tag.__class__)

在这里插入图片描述
可以看到,要的标签就是data里的值,那么怎么提取data里的值呢

3.3.3 提取标签字符串:extract函数

extract这个单词本身就是提取的意思,提取data里的值,返回为字符串list,因为有可能有多个值

from scrapy import Selector
sel=Selector(text=html).extract()
print(sel)
print(sel.__class__)

在这里插入图片描述

返回的是一个list,因为有可能有多个值,取第一个值就在extract()后面加个[0]

sel=Selector(text=html)
tag0=sel.xpath("//*[@id='bbb-9999']/p").extract()
tag=sel.xpath("//*[@id='bbb-9999']/p").extract()[0]
print(tag0)
print(tag0.__class__)
print(tag)
print(tag.__class__)

在这里插入图片描述
注意:extract()返回的list可能是个空值,这时候取[0]会抛异常,所以最好做下判断
在这里插入图片描述

3.3.4 提取标签里的内容

3.3.4.1 text()

在xpath(“//*[@id=‘bbb-9999’]/p[1]”)中的xpath表达式的后面加上/text()就可以获得所找标签的内容
源码参考:
在这里插入图片描述

sel=Selector(text=html)
tag=sel.xpath("//*[@id='bbb-9999']/blockquote/p/text()").extract()
print(tag)
print(tag.__class__)

在这里插入图片描述

sel=Selector(text=html)
tag=sel.xpath("//*[@id='bbb-9999']/blockquote/p/text()").extract()[0]
print(tag)
print(tag.__class__)

在这里插入图片描述

3.3.4.2 再反向演示一下extract的作用
sel=Selector(text=html)
tag=sel.xpath("//*[@id='bbb-9999']/blockquote/p/text()")
print(tag)
print(tag.__class__)

在这里插入图片描述

3.4.4.3 代码灵活化
sel=Selector(text=html)
name_xpath="//*[@id='bbb-9999']/blockquote/p/text()"
name=""
tag_texts=sel.xpath(name_xpath).extract()
if tag_texts:
    name=tag_texts[0]
print(name)
3.3.4.2 关于多值属性
3.3.4.2.1 直接写@class要把所有属性都写上
sel=Selector(text=html)
tag=sel.xpath("//div[@class='aaa aa']/p/text()").extract()
print(tag)

源码参考:
在这里插入图片描述
运行结果:
在这里插入图片描述
那要是这个class属性又多又长,都要写上岂非太烦?所以有一个叫contains的函数,可实现四两拨千斤。

3.3.4.2.2 contains函数
sel=Selector(text=html)
tag=sel.xpath("//div[contains(@class,'aa')]/p/text()").extract()
print(tag)

运行结果:
在这里插入图片描述
源码参考:
在这里插入图片描述
用contains,就算class的一个值没有写完整也可以查,比如上面,我写个a来查也可以
除了contains,其它内置方法还有很多,可以去https://developer.mozilla.org/en-US/docs/Web/XPath/Functions查看

还可以直接获取属性:

sel=Selector(text=html)
tag=sel.xpath("//div[contains(@class,'aa')]/@class")
print(tag)

在这里插入图片描述

tag=sel.xpath("//div[contains(@class,'aa')]/@class").extract()
print(tag)

在这里插入图片描述
另一个示例
在这里插入图片描述
|在xpath里是和的意思

3.4 xpath的一些实用技巧和注意事项

①xpath括号里的语法是从1开始的。
②如果一列标签要截取里面的一段,可以用列表里切片的方法:
在这里插入图片描述
③可以以已经得到的xpath对象再进行xpath语法
在这里插入图片描述

在这里插入图片描述
. 代表当前元素item

抱歉,我并不是一个可以运行代码的程序,我只能提供一些帮助和指导。 针对您的问题,您需要使用Python编写爬虫程序,利用正则表达式、requests库的请求、IP代理、XPath工具、lxml库、BeautifulSoup库、Selenium和WebDriver等技术,爬取目标网站https://book.douban.com/top250上的250条信息,并按照书名、作者、出版社、出版时间、售价、评分、评价人数以及评论(评论只取第一条)共计9个字段进行解析,最后将解析文件存储为csv文件类型,文件名为Tdata.csv。 这是一个较为复杂的任务,需要您具备一定的Python编程基础和网络爬虫的知识。以下是一个大致的步骤: 1.分析目标网站的页面结构,确定需要爬取的数据所在的位置和标签。 2.编写Python代码,利用requests库发送请求,获取目标网站的HTML页面。 3.利用XPathBeautifulSoup等工具解析HTML页面,从中提取需要的数据。 4.使用正则表达式对数据进行清洗和处理,使其符合要求。 5.使用Selenium和WebDriver模拟浏览器行为,解决反爬虫机制和IP封禁等问题。 6.将解析后的数据保存为csv文件类型,文件名为Tdata.csv。 注意事项: 1.在发送请求时,需要设置IP代理,防止被目标网站封禁IP。 2.在解析HTML页面时,需要注意某些标签可能不存在或格式不统一的情况,需要编写相应代码进行异常处理。 3.在使用Selenium和WebDriver时,需要注意浏览器的版本和驱动程序的选择,以及浏览器的设置和窗口控制等问题。 4.在保存csv文件时,需要注意编码格式和文件路径等问题。 希望这些信息能够对您有所帮助,祝您成功完成爬虫任务!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值