详解Selenium如何实现获取cookies并保存

 更新时间:2023年05月05日 14:22:46   作者:虚坏叔叔  
这篇文章主要为大家详细介绍了Selenium如何实现获取cookies保存起来用于下次访问,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下

一、获取cookie

获取到cookie后,保存到文件中

from selenium import webdriver
import time
import json
from selenium.webdriver.common.by import By

#创建webdriver 对象,指明使用chrome 浏览器驱动
wd = webdriver.Chrome()

wd.implicitly_wait(10)

#调用webdriver 对象的get方法,可以让浏览器打开指定网址
wd.get('https://zhidao.baidu.com/activity/iknowduck/level?actId=47')
input('网页端登录百度账号后,请按回车键')
cookie= wd.get_cookies()
# #将获得cookie 的信息打印
print(cookie)
with open('baiducookies.txt','w') as f:
    # 将cookies保存为json格式
    f.write(json.dumps(wd.get_cookies()))
    f.close()

二、加载cookie

通过读取txt文件,添加到浏览器中

wd.add_cookie(cookie)

完整的读取cookie的流程

from selenium import webdriver
import time
import json
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.chrome.options import Options
from chatgpt_demo import chatgpt

#创建webdriver 对象,指明使用chrome 浏览器驱动
wd= webdriver.Chrome()
wd.implicitly_wait(10)

#调用webdriver 对象的get方法,可以让浏览器打开指定网址
wd.get('https://zhidao.baidu.com/activity/iknowduck/level?actId=47')
# 首先清除由于浏览器打开已有的cookies
wd.delete_all_cookies()
time.sleep(10)
#打开cookie文本,使用已保存的cookie登录
with open('baiducookies.txt','r') as f:
    # 使用json读取cookies 注意读取的是文件 所以用load而不是loads
    cookies_list = json.load(f)
    for cookie in cookies_list:
        wd.add_cookie(cookie)
wd.refresh() #刷新页面
wd.refresh() #刷新页面
time.sleep(6)
#获取当前窗口的title
First_handle = wd.current_window_handle
j = 0
while j < 60:
#try:
    for i in range(9):
        n = 1
        #点击第一个问题
        questions = wd.find_elements(By.CSS_SELECTOR, 'div.q-item > div.q-title > span:nth-child(2) ')
        for question in questions:
            print('第{}个问题:'.format(n), question.text)
            n += 1

            #将第一个问题,输入catgpt在线智能回答
            message = chatgpt(question.text)
            print(message)
            #with open("./output/{}.doc".format(prompt), "w") as of:
            #    of.write(message)
            titles = question.text + '_百度知道'
            time.sleep(1)
            #点击“回答”,按钮
            # answer = wd.find_element(By.CSS_SELECTOR,'.goto-anwser-btn')
            # print('点击:',answer.text)
            wd.add_cookie(cookie) #带cookie
            question.click() #点击问题
            time.sleep(3)
            #切换窗口,点击“去回答”按钮时,打开了新的窗口,但WebDriver对象对应的 还是老窗口。这里要跟随跳转
            for handle in wd.window_handles:
                # 先切换到该窗口
                wd.switch_to.window(handle)
                # 得到该窗口的标题栏字符串,判断是不是我们要操作的那个窗口
                if 'titles' in wd.title:
                    # 如果是,那么这时候WebDriver对象就是对应的该该窗口,正好,跳出循环,
                    break
            #print(wd.title)

            #新窗口下,不管是否已有其他回答,都点击“我来答按钮”
            element = wd.find_element(By.CSS_SELECTOR, '#answer-bar')
            element.click()#点击“我来答按钮”
            #输入文本
            #新窗口,切换到第一级iframe框下,正文内容
            wd.switch_to.frame('ueditor_0')
            element = wd.find_element(By.CSS_SELECTOR,'body > p')
            print('正在输入答案')
            element.send_keys(message)
            #先返回到主html,点击提交按钮
            wd.switch_to.default_content()
            time.sleep(50)
            element = wd.find_element(By.CSS_SELECTOR,'div.addons.line > a')
            print(element.text)
            wd.add_cookie(cookie)  # 带cookie
            element.click()
            time.sleep(5)
            #做完一系列操作后关闭school_handle
            wd.close()
            # 切换窗口会第一个窗口
            wd.switch_to.window(First_handle)
#except:
    print("出错{}次,正在重新运行程序。".format(j))
    j += 1
    wd.switch_to.window(First_handle)
    time.sleep(5)
    wd.refresh()  # 刷新页面
else:
    print('出错太多次啦,程序已结束')

到此这篇关于详解Selenium如何实现获取cookies并保存的文章就介绍到这了,更多相关Selenium获取cookies内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python队列Queue的详解

    python队列Queue的详解

    这篇文章主要介绍了python队列Queue,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • Python设计模式优雅构建代码全面教程示例

    Python设计模式优雅构建代码全面教程示例

    Python作为一门多范式的编程语言,提供了丰富的设计模式应用场景,在本文中,我们将详细介绍 Python 中的各种设计模式,包括创建型、结构型和行为型模式
    2023-11-11
  • 如何利用opencv对拍摄图片进行文字识别

    如何利用opencv对拍摄图片进行文字识别

    在有些工程中有时候我们需要对图片文字识别,下面这篇文章主要给大家介绍了关于如何利用opencv对拍摄图片进行文字识别的相关资料,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • 通过 for 循环比较 Python 与 Ruby 的编程区别

    通过 for 循环比较 Python 与 Ruby 的编程区别

    这篇文章主要介绍了通过 for 循环比较 Python 与 Ruby 的编程区别,Ruby 与 Python 之间的差异在很大程度上可通过for循环看出本质,下文详细介绍需要的小伙伴可以参考一下
    2022-05-05
  • Python魔术方法深入分析讲解

    Python魔术方法深入分析讲解

    所谓魔法函数(Magic Methods),是Python的⼀种⾼级语法,允许你在类中⾃定义函数(函数名格式⼀般为__xx__),并绑定到类的特殊⽅法中。⽐如在类A中⾃定义__str__()函数,则在调⽤str(A())时,会⾃动调⽤__str__()函数,并返回相应的结果
    2023-02-02
  • Python中非常好用的内置函数详解

    Python中非常好用的内置函数详解

    这篇文章主要为大家介绍了Python中非常好用的内置函数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • 浅谈Python2获取中文文件名的编码问题

    浅谈Python2获取中文文件名的编码问题

    下面小编就为大家分享一篇浅谈Python2获取中文文件名的编码问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Python格式化字符串的案例方法

    Python格式化字符串的案例方法

    在编写程序的过程中,经常需要进行格式化输出,每次用每次查,干脆就在这里整理一下,下面这篇文章主要给大家介绍了关于python字符串格式化的相关资料,分别是%格式符和format方式,需要的朋友可以参考下
    2022-03-03
  • Python中的pandas库简介及其使用教程

    Python中的pandas库简介及其使用教程

    pandas是用于数据挖掘的Python库,Pandas中常见的数据结构有Series和DateFrame两种方式,今天通过本文给大家讲解Python中的pandas库简介及其使用,感兴趣你跟随小编一起学习吧
    2022-11-11
  • 浅谈python中的__init__、__new__和__call__方法

    浅谈python中的__init__、__new__和__call__方法

    这篇文章主要给大家介绍了关于python中__init__、__new__和__call__方法的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友可以参考学习,下面来跟着小编一起看看吧。
    2017-07-07

最新评论