python贴吧回帖-python控制浏览器爬取百度贴吧回复并写入Excel

[Python] 纯文本查看 复制代码# http://tieba.baidu.com/i/i/my_reply

from selenium import webdriver

import time

from bs4 import BeautifulSoup

import xlwt

def login(name, passwd):

# 1.打开浏览器

driver = webdriver.Chrome()

# 2.设置地址

url = "https://www.baidu.com/"

# 3.访问网址

driver.get(url)

# 4.分析网页,找到登录元素

# login = driver.find_elements_by_id('u1').find_elements_by_class_name('lb')[0] #方法一

login = driver.find_elements_by_css_selector('div[id=u1] a[class=lb]')[0] #方法二

#5.点击登录按钮

login.click()

time.sleep(2)

changeusename=driver.find_element_by_id("TANGRAM__PSP_10__footerULoginBtn")

changeusename.click()

#点击之后要加等待时间

time.sleep(2)

#8.找到 输入 用户名 和密码框,并且设置内容

#

username = driver.find_element_by_id('TANGRAM__PSP_10__userName')

#输入账号名

username.send_keys(name)

time.sleep(1)

#

password = driver.find_element_by_id('TANGRAM__PSP_10__password')

#输入密码

password.send_keys(passwd)

time.sleep(2)

#

submit = driver.find_element_by_id('TANGRAM__PSP_10__submit')

submit.click()

return driver

def opentieba(browser, url = 'http://tieba.baidu.com/i/i/my_reply?&pn=1'):

browser.get(url)

context=browser.page_source

soup = BeautifulSoup(context, 'html.parser')

context=browser.find_element_by_css_selector(".simple_block_container")

print(context.text)

cont=soup.find_all(class_='b_right_up')

return cont

def writeXls(cont):

i = 0 # 从第几行开始写

# 1、导入模块

# 2、创建workbook(其实就是excel,后来保存一下就行)

# workbook = xlwt.Workbook(encoding='ascii')

workbook = xlwt.Workbook(encoding = 'utf-8')

# 3、创建表

worksheet = workbook.add_sheet('sheet1')

for link in cont:

print(link)

item = BeautifulSoup(str(link), 'html.parser')

reply_context=item.find(class_="for_reply_context")

thread_title=item.find(class_="thread_title")

href = str(thread_title)[31:54]

href = 'http://tieba.baidu.com/' + href

print(reply_context.text)

worksheet.write(i, 0, label=reply_context.text)

print(thread_title.text)

worksheet.write(i, 1,xlwt.Formula('HYPERLINK("'+href+'"," '+thread_title.text+'")'))

print(href)

i = i + 1

time.sleep(1)

# 5、保存

date = time.strftime("%Y%m%d%H%M%S", time.localtime())+ '_'

workbook.save('Excel_'+date+str(i)+'.xls')

i = 0

return "successful"

def writedata(data):

#1、导入模块

#2、创建workbook(其实就是excel,后来保存一下就行)

workbook = xlwt.Workbook(encoding='ascii')

# 3、创建表

worksheet = workbook.add_sheet('sheet1')

#4、往单元格内写入内容

worksheet.write(0, 0, label=data)

# 5、保存

workbook.save('Excel_Workbook.xls')

def main():

driver = login("美食拍客136822", "*****")

str = input("请输入任意内容确认你已经登录:")

xlscontext = opentieba(driver, url = 'http://tieba.baidu.com/i/i/my_reply?&pn=1')

res = writeXls(xlscontext)

print(res)

if __name__ == '__main__':

main()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值