Python之爬虫和数据小解析


Holi需要。
之前爬的课表,现在需要将那些个一连串的字符串分割成想要的单独的数据,做个性化推送。

程序的前面和之前一样,模拟登录。
在处理选课/改课这个网页的时候,还是蛮复杂的。
遇神杀神,见鬼杀鬼。

爬虫

   def Store(self):
        # 改课选课
        grade_page = self.session.get(
            "http://yjsxt.xidian.edu.cn/electiveForwardAction.do")

        bsObj = BeautifulSoup(grade_page.text, "html.parser")
        table = bsObj.findAll("table", {
  "class": "list_2title"})[0]
        rows = table.findAll("tr")
        # 删除特定的标签和其标签下的内容
        # 方法:
        # 去除标签:[s.extract() for s in soup('script')]

        [s.extract() for s in bsObj.findAll(
            'td', attrs={
  'class': "special_background textLeft"})]

        csvFile = open('./xuankegaike.csv', 'w', newline='', encoding='utf-8')
        writer = csv.writer(csvFile)

        writer.writerow(('课程编号', '课程名称', '学分', '学位课', '上课学期',
                         '任课教师', '校区', '上课地点/星期/节次/周次', '分班号'))
        csvRow = []

        try:
            for row in rows:
                csvRow = []

                # for cell in row.findAll('td')[:-1]:
                for cell in row.findAll('td', attrs={
  'valign': "middle"})[:-1]:
                    csvRow.append(cell.get_text().strip().replace(' ', ''))
                writer.writerow(csvRow)
        finally:
            csvFile.close()

        csvFile1 = open('./xuankegaike.csv', 'r', encoding='utf-8')
        reader = csv.DictReader(csvFile1)

正个页面有一张大table,但是里面分布的真不整齐。

新方法s.extract():

删除特定的标签和其标签下的内容
方法:
去除标签:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值