通过这次爬取,学习了数据库MySQL,因为之前都是在windows上操作,而这回需要在Mac上操作,所以就在Mac上安装了MySQL以及MySQL的管理工具Sequel Pro,最后也是安装成功,数据库连接也没有问题。
接下来创建数据库,表格及主键信息。
import pymysql
创建数据库
db = pymysql.connect(host=‘127.0.0.1’, user=‘root’, password=‘774110919’, port=3306)
cursor = db.cursor()
cursor.execute(“CREATE DATABASE QQ_Music DEFAULT CHARACTER SET utf8mb4”)
db.close()
import pymysql
创建表格, 设置主键
db = pymysql.connect(host=‘127.0.0.1’, user=‘root’, password=‘774110919’, port=3306, db=‘QQ_Music’)
cursor = db.cursor()
sql = ‘CREATE TABLE IF NOT EXISTS comments (nike VARCHAR(255) NOT NULL, comment VARCHAR(255) NOT NULL, praisenum INT NOT NULL, comment_id VARCHAR(255) NOT NULL, time VARCHAR(255) NOT NULL, PRIMARY KEY (comment))’
cursor.execute(sql)
db.close()
针对音乐中去年夏天的网页进行分析,查看了所有评论的尾页,发现时间缩水了,因为热评中有一条评论的时间7月12号,而所有评论最后一页的时间却是7月16号。很明显,所有评论并不是货真价实的所有评论,不知这算不算音乐的BUG。
还有一个就是直接点击最后一页的时候,并不能直接返回真正的信息,需要从最后一页往前翻,到了真正的信息页时,然后再往后翻,才能得到最后一页的真正信息。
同样是Ajax请求,确认网址后,分析一下请求头,发现主要是三个参数发生变化:jsoncallback
pagenum
lasthotcommentid
pagenum不难理解,就是页数。jsoncallback经过实验后,发现并不会影响请求,所以设置时无需改动,lasthotcommentid的值对应的是上一页最后一个评论者的ID,所以需要随时改动。
即改变pagenum,lasthotcommentid的值,就可成功实现请求。
部分代码
import re
import json
import time
import pymysql
import requests
URL = ‘https://c.y.qq.com/base/fcgi-bin/fcg_global_comment_h5.fcg?’
HEADERS = {
‘user-agent’: ‘Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36’
}
PARAMS = {
‘g_tk’: ‘5381’,
‘jsonpCallback’: ‘jsoncallback4823183319594757’,
‘loginUin’: ‘0’,
‘hostUin’: ‘0’,
‘format’: ‘jsonp’,
‘inCharset’: ‘utf8’,
‘outCharset’: ‘GB2312’,
‘notice’: ‘0’,
‘platform’: ‘yqq’,
‘needNewCode’: ‘0’,
‘cid’: ‘205360772’,
‘reqtype’: ‘2’,
‘biztype’: ‘1’,
‘topid’: ‘213910991’,
‘cmd’: ‘8’,
‘needmusiccrit’: ‘0’,
‘pagenum’: ‘0’,
‘pagesize’: ‘25’,
‘lasthotcommentid’: ‘’,
‘callback’: ‘jsoncallback4823183319594757’,
‘domain’: ‘qq.com’,
‘ct’: ‘24’,
‘cv’: ‘101010’,
}
一、Python所有方向的学习路线
Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、学习软件
工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
三、入门学习视频
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Python爬虫全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:python)
了一份《2024年Python爬虫全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:python)
[外链图片转存中…(img-EYWoqSss-1711459541194)]