python爬虫实践--晋江小说书籍分析

系列文章目录

python爬虫实践–晋江小说书籍分析
python爬虫实践-腾讯视频弹幕分析
python爬虫实践-B站弹幕分析



## 前言 寒假在家看小说,看着看着想自己写,然后申了几次没过,打算把榜单文章拿来好好分析一下,做个高大上的词云看看方向什么的。 但我不会爬虫,只听说过,就上网搜别人的代码,但是别人的代码不满足我的需求,我看不懂也改不了。

凭着一口我也是程序人的志气(主要恰好学了python),自己去搜了怎么写爬虫,把视频看了一遍,过了下大概思路,然后看第二遍,注意一些细节,跟着一步一步地做自己的(主要是用他的思路和跟着写一点语句),最后就把晋江上我需要的数据搞出来了。(默默夸一句,beautifulSoup真真真好用)
1月份那阵的排行,爬了一百本

目录

软件是pycharm(社区版不要钱的那种)

爬取晋江排行榜

思路,看懂学习视频,自己用那样的思路去解自己想要提取信息的网站。
我也遇到很多问题,查了很多资料,看得头都要秃了,但最后做出来的成就感真的很大。
爬虫的学习视频链接如下:
https://www.bilibili.com/video/BV12E411A7ZQ
老师讲得很清晰很有条理!!(声音很好听,就是没有看到脸。)
代码

# -*- codeding = utf-8 -*-
# @Time : 2021/1/22 14:12
# @Author : ljr
# @File : lx1.py
# @Software : PyCharm

#爬取晋江文学城排行榜前一百的书籍名字,链接,字数

import urllib
import urllib.request
from bs4 import BeautifulSoup
import re
import xlwt
import sqlite3

def main():
    baseurl = "http://www.jjwxc.net/bookbase.php?fbsj12=12&ycx1=1&xx1=1&xx2=2&page="
    # 1.爬取网页
    datalist = getData(baseurl)
    print(len(datalist))
    savepath = ".\\晋江小说.xls"
    # dbpath = "book.db"
    # 3.保存数据
    saveData(savepath,datalist)
    # saveDataDb(datalist, dbpath)

#先准备的提取信息内容的正则表达式
findName = re.compile(r'">(.*?)</a>',re.U)
findLink = re.compile(r'<a href="(.*?)"')
findSize = re.compile(r'<td align="right">(\d+)</td>')

# 1.爬取网页(完成)
def getData(baseurl):
    datalist = []
    for i in range(1,4):    #搜索结果的页数
        url = baseurl + str(i)
        html = askURL(url)
        # 2.逐一解析
        soup = BeautifulSoup(html, "html.parser")
        i = 0
        for item in soup.findAll('tr'):
            data = [] # 保存一本书的所有信息
            item = str(item)
            # 提取文名
            Name = re.findall(findName, item)
            # 提取文章链接
            Link = re.findall(findLink, item)
            # 提取字数
            Size = re.findall(findSize, item)
            if i:
                data.append(Name[1])
                Link[1]='http://www.jjwxc.net/' + Link[1]
                data.append(Link[1])
                data.append(Size[0])
                datalist.append(data)
            i = 1
    return datalist

# 2.得到指定一个URL的网页的内容
def askURL(url):
    head = {
   
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.141 Safari/537.36 Edg/87.0.664.75"
    }

    request = urllib.request.Request(url,headers=head)
    html = ""
    try:
        response = urllib.request.urlopen(request)
        html = response.read().decode('GBK')
        <
  • 42
    点赞
  • 182
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
解锁网络数据的宝藏:Python爬虫工具与教程集合 一、探索网络信息的无限宝藏 在互联网的海洋中,蕴藏着海量的有价值信息。如何合法、高效地获取这些信息?Python爬虫工具与教程为您揭开这一神秘面纱。通过这些资源,您可以轻松地爬取网站信息,提取所需内容,为各种应用场景提供强大的数据支持。 二、资源亮点 工具齐全:提供一系列功能强大的Python爬虫工具,满足您不同场景下的需求。 教程详尽:配套的Python爬虫教程,从基础到进阶,让您逐步掌握爬虫的核心技术。 合法合规:严格遵守法律法规和网站使用协议,确保采集行为合法,尊重网站权益。 实战项目:结合实际案例,让您在实践中掌握Python爬虫的运用,真正做到学以致用。 三、适用人群 无论您是数据分析师、网络开发者还是对Python爬虫感兴趣的爱好者,这些资源都将为您的学习和实践提供有力的支持。 四、使用建议 按需选择工具与教程:根据实际需求选择合适的工具和教程,确保学习与实践的有效性。 遵守法律法规与协议:在使用这些资源进行爬取活动时,务必遵守相关法律法规和网站的使用协议。 持续学习与更新:随着网络技术的不断进步,Python爬虫技术也在不断发展。建议您持续关注相关动态,提升自己的技能水平。 五、安全与责任 尊重网站权益:避免对目标网站的正常运行造成干扰或损害,合理使用资源。 隐私保护:在采集数据时,严格遵守隐私保护法规,不泄露或滥用用户个人信息。 风险防范:了解并应对潜在的网络威胁,采取相应措施降低风险。 感谢您选择我们的Python爬虫工具与教程集合!让我们一起挖掘网络信息的宝藏,为您的工作和研究注入新的活力!请务必遵守法律法规和网站使用协议,共同维护网络数据的合法采集与利用
晋江文学网是一个知名的在线文学阅读平台,而PHP是一种广泛应用于Web开发的脚本语言。下面是针对晋江文学网PHP面试题的回答: 1. 请简要介绍一下PHP。 PHP全称为“PHP: Hypertext Preprocessor”,是一种被广泛应用于Web开发的脚本语言。它可以嵌入HTML中,通过服务器端解析执行,生成动态网页内容。PHP是开源的,语法简单易学,具有极高的扩展性和稳定性,因此受到了广泛的应用和认可。 2. 请描述一下PHP中的GET和POST的区别。 GET和POST是HTTP协议中常用的两种请求方法,用于向服务器传递数据。GET通过请求URL的参数传递数据,数据会附加在URL之后,以问号(?)分隔;而POST通过HTTP请求的消息实体传递数据,数据不会显示在URL中。 GET适用于获取数据的操作,通常用于查看页面、点击链接、发送搜索等场景;POST适用于提交数据的操作,用于表单提交、注册用户、发送请求等场景。因为GET是通过URL传递数据,所以参数有长度限制,而POST的数据则没有限制。 3. 请简要介绍一下Cookie和Session的区别。 Cookie和Session都是用于在服务器和客户端之间保持状态的机制。 Cookie是一种由服务器发给客户端保存的小数据文件,保存在客户端的浏览器中。通过设置过期时间,在浏览器访问同一网站时,会自动携带相应的Cookie信息发送给服务器。Cookie的安全性相对较低,用户可以手动编辑和删除。 Session是一种基于服务器的数据保存机制,服务器会在客户端第一次访问时创建一个唯一的标识,并将该标识保存在Cookie中,同时在服务器端创建一个对应的Session文件。之后客户端每次请求都会携带该标识,服务器通过该标识识别用户,从而实现用户状态的保存。相比Cookie,Session的安全性更高,用户无法直接修改和删除Session。 总的来说,Cookie适用于保持较小的数据量,而Session适用于保持较大的数据量和较高的安全性要求。 以上是对晋江文学网PHP面试题的简要回答,希望对你有帮助。如果有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值