Python——Selenium快速上手+方法(一站式解决问题)

目录

前言

一、Selenium是什么

二、Python安装Selenium

1、安装Selenium第三方库

2、下载浏览器驱动

3、使用Python来打开浏览器

三、Selenium的初始化

四、Selenium获取网页元素

4.1、获取元素的实用方法

1、模糊匹配获取元素 & 联合多个样式

2、使用拉姆达表达式

3、加上睡眠时间,增加容错

4、合理利用树形结构

4.2、获取网页元素失败怎么办?

1、确保4.1的方法都使用正确!!

2、检查我们的代码,获取的那个代码,是否有问题

3、iframe的问题

4、网页跳转的问题

五、Selenium点击元素的方法

在 Selenium 中触发点击事件(最常用的三种方法)

1、使用 click() 方法:

2、使用 JavaScript 执行点击事件:

3、使用 ActionChains 类:

另外四种(不常用)

4、使用 send_keys(Keys.RETURN) 模拟回车键:

5、使用 submit() 方法提交表单:

6、使用 JavaScript 修改元素属性:

7、使用 Robot 类模拟物理点击:

六、Selenium+browsermob-proxy获取网络请求

1. 下载browsermob-proxy.bat

 2.安装python模块browsermob-proxy

3、编写代码


前言

在实习的时候,需要做一些爬虫,所以就接触到了Selenium

再开始就使用调用接口,所以需要去逆向找RSA加密算法的key,或者其他加密的东西

后面发现,不管是黑猫还是白猫,抓到老鼠就是好猫

逆向网页这玩意,我是真不懂,又没有兴趣去研究

所以还是大道至简,直接用Selenium抓取网页数据吧,简单方便!

一、Selenium是什么

Selenium是一个用于自动化web应用程序测试的工具。它提供了一组工具和库,可以用多种编程语言(如Java、Python、C#等)编写测试脚本,模拟用户在浏览器中的行为,如点击链接、填写表单、提交数据等。Selenium可以在各种浏览器上运行,包括Chrome、Firefox、Safari等,它还可以与其他测试框架和工具集成,帮助开发人员和测试人员自动化执行各种测试任务,提高测试效率和质量。


官网:

SeleniumSelenium automates browsers. That's it!icon-default.png?t=N7T8https://www.selenium.dev/Selenium是支持多种语言的

这里只说关于Python的

二、Python安装Selenium

1、安装Selenium第三方库

我习惯用4.6低版本的

# 换源
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple

# 安装我这个版本
pip install selenium==4.6.0

# 安装默认最新版本
pip install selenium

下载Selenium后,我们需要他来打开浏览器,

但是Selenium需要有浏览器驱动,才可以打开浏览器

2、下载浏览器驱动

下面是Selenium目前支持的浏览器

这里只介绍如何下载谷歌浏览器的驱动,因为我只用过谷歌浏览器的

先确定自己的谷歌浏览器的版本

打开谷歌浏览器,输入地址:

chrome://settings/help

可以查看自己的版本:

选择对应版本号的驱动版本


下载地址:
https://chromedriver.storage.googleapis.com/index.html


这里记录下最新版本谷歌驱动器下载地址:
https://googlechromelabs.github.io/chrome-for-testing/ 

我这里打包上传了几个版本的驱动,有需要的,自取:

2024-5-最近几个版本的谷歌浏览器驱动.zip - 蓝奏云文件大小:46.9 M|icon-default.png?t=N7T8https://wwm.lanzout.com/iNYDd20cs3ef

3、使用Python来打开浏览器

一般情况下,一些博主推荐存放在python的安装路径

那个只能说方便了我们自己使用,可以快速跑代码demo

但是,当我们需要项目打包,在其他电脑上运行的时候,浏览器驱动放哪里?

这就是一个问题!

所以我们需要实现设置好驱动的路径

我就是直接放在D盘

运行代码demo

from selenium import webdriver

# 设置Chrome浏览器驱动程序的路径
chrome_driver_path = "D:\\chromedriver.exe"

# 初始化Chrome浏览器
browser = webdriver.Chrome(executable_path=chrome_driver_path)

# 打开百度网页
browser.get("https://www.baidu.com")

# 这里可以编写其他与页面交互的代码

# 关闭浏览器
browser.quit()

当我们看见百度网页后,浏览器就会关闭,这样就说明我们设置完成了

三、Selenium的初始化

当我们创建浏览器驱动对象的时候,他会创建一个新的干净的浏览器,来供我们使用

from selenium import webdriver

# 设置Chrome浏览器驱动程序的路径
chrome_driver_path = "D:\\chromedriver.exe"

# 初始化Chrome浏览器
browser = webdriver.Chrome(executable_path=chrome_driver_path)

所以,我们在浏览器上设置的东西,也可以通过代码实现设置好

比如:

  • 浏览器下载文件后,下载的地址设置
  • 浏览器是否加载图片
  • 浏览器是否禁用JS
  • 浏览器是否使用隐私模式
  • 浏览器是否使用缓存

等等...

因此,我们可以实现封装一个类,来实现浏览器的初始化

我写的一个简单类,可以通过json文件来修改参数

比如:

获取驱动的路径(在打包后,我们的驱动也需要在生产环境中,让程序可以找到,这时候我们灵活修改)

是否加载图片

是否使用缓存

等等

下面的代码,只适用4.8以下低版本的哟~

# -*- coding: utf-8 -*-
# @Author : pan
# @Description : 获取浏览器驱动模块
# @Date : 2024年5月25日17:53:17

'''
    # # 无界面化.
    # chrome_opt.add_argument('--headless')

    # # 配合上面的无界面化.
    # chrome_opt.add_argument('--disable-gpu')
    # 设置窗口大小, 窗口大小会有影响.
    # chrome_opt.add_argument('--window-size=1366,768')

    # 不加载图片, 提升速度
    # chrome_opt.add_argument('--blink-settings=imagesEnabled=false')
    # # 使用沙盒模式运行
    # chrome_opt.add_argument("--no-sandbox")
    # 远程操控
    # chromedriver = webdriver.Remote(_chromedriverUrl, options=chrome_opt)
    # 自动接受警告和对话框
    # chrome_opt.add_argument('--auto-open-devtools-for-tabs')
    # 忽略SSL错误:对于测试环境中自签名证书的站点。
    chrome_opt.add_argument('--ignore-certificate-errors')
    # chromedriver.set_page_load_timeout(30)  # 设置页面加载超时时间
    # chromedriver.execute_cdp_cmd("Page.setCacheDisabled", {"cacheDisabled": True})  # 禁用缓存
    # 自定义Chrome的数据存储目录,用于持久化Cookies、存储等。
    # chrome_opt.add_experimental_option('prefs', {'profile.default_content_settings.popups': 0,
    #                                              'download.default_directory': '/path/to/download'})
    # # 创建一个临时目录来存储浏览器会话的数据
    #     user_data_dir = "/path/to/temp/dir"  # 替换为你希望存储临时数据的路径
    #     if os.path.exists(user_data_dir):
    #         shutil.rmtree(user_data_dir)  # 如果目录已存在,则删除它
    #     os.makedirs(user_data_dir)  # 创建新的临时目录
    #
    # chrome_opt.add_argument(f"user-data-dir={user_data_dir}")
    # 设置代理
    # chrome_opt.add_argument('--proxy-server=http://ip:port')
    # chrome_opt.add_argument('--proxy-server=http://127.0.0.1:8888')
    # 启动无痕模式
    # chrome_opt.add_argument('--incognito')
    # 禁用扩展
    # chrome_opt.add_argument('--disable-extensions')
    # 禁用JS
    # chrome_opt.add_argument('--disable-javascript')
    # 用户代理设置:模拟不同的浏览器或设备访问。
    # chrome_opt.add_argument('--user-agent=Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3')

'''

import time
import json
import os
from dataclasses import dataclass, asdict

from selenium import webdriver


@dataclass
class WebDriveConf:
    """
    浏览器驱动配置
    """
    chromedriver_url: str = 'D:\\chromedriver.exe'  # 浏览器驱动路径
    user_data_dir: str = 'D:\\webDriverTempDir'  # 存储临时数据的路径
    is_use_cache: int = 0   # 是否使用缓存
    is_load_page: int = 1   # 是否加载页面
    is_load_img: int = 0   # 是否加载图片
    is_ignore_certificate: int = 1  # 是否忽略证书
    is_incognito: int = 1  # 是否启动无痕模式

    def to_dict(self) -> dict:
        """
        返回配置信息的 JSON 格式表示

        Returns:            dict: 配置信息的 JSON 格式表示
        """
        return asdict(self)

    def read_json_config(self, file_path: str) -> dict:
        """
        从 JSON 文件中读取配置信息并返回字典
        Args:        file_path (str): JSON 文件路径

        Returns:        dict: 包含配置信息的字典
        """
        # 检查文件是否存在
        if not os.path.exists(file_path):
            # 如果文件不存在,则创建一个包含默认配置信息的 JSON 文件
            with open(file_path, "w") as file:
                json.dump(self.to_dict(), file, indent=4)

        # 读取配置文件
        with open(file_path, "r") as file:
            config_dict = json.load(file)
        return config_dict

    def write_json_config(self, config_dict: dict, file_path: str):
        """
        将配置信息写入 JSON 文件
        Args:        config_dict (dict): 包含配置信息的字典
            file_path (str): JSON 文件路径
        """
        with open(file_path, "w") as file:
            json.dump(config_dict, file, indent=4)

class ChromeWebDriver:

    def __init__(self, conf: WebDriveConf):
        self.conf = conf
        self.chrome_opt = webdriver.ChromeOptions()
        self.chrome_opt.add_argument('--user-data-dir=' + self.conf.user_data_dir)
        # 判断是否使用缓存 (如果不使用缓存,则删除缓存文件)
        if not self.conf.is_use_cache:
            if os.path.exists(self.conf.user_data_dir):
                # 删除这个文件夹
                import shutil
                shutil.rmtree(self.conf.user_data_dir)

        # 判断是否有文件夹
        if not os.path.exists(self.conf.user_data_dir):
            os.makedirs(self.conf.user_data_dir)

        # 无界面化
        if not self.conf.is_load_page:
            self.chrome_opt.add_argument('--headless')
        # 是否加载图片
        if not self.conf.is_load_img:
            self.chrome_opt.add_argument('--blink-settings=imagesEnabled=false')
        # 是否忽略证书
        if self.conf.is_ignore_certificate:
            self.chrome_opt.add_argument('--ignore-certificate-errors')
        # 启动无痕模式
        if self.conf.is_incognito:
            self.chrome_opt.add_argument('--incognito')
        # 创建 Chrome WebDriver 实例
        self.chromedriver = webdriver.Chrome(executable_path=self.conf.chromedriver_url, options=self.chrome_opt)


if __name__ == '__main__':

    # 创建 WebDriveConf 实例并解包配置信息
    web_driver_conf = WebDriveConf(**WebDriveConf().read_json_config("web_driver_conf.json"))

    # 创建 ChromeWebDriver 实例
    chrome_web_driver = ChromeWebDriver(web_driver_conf)

    # 打开网页
    chrome_web_driver.chromedriver.get("https://www.bilibili.com/?spm_id_from=333.788.0.0")

    time.sleep(10)

    chrome_web_driver.chromedriver.quit()


四、Selenium获取网页元素

首先,我们需要了解网页的结构,打开网页按F12,或者右键页面,然后点击【检查】

即可看见到我们的开发者界面

就可以html代码了,那个元素就想树形图一样的排列,所以我们获取的方法有很多种

现在默认你有前端的基础,了解HTML

当我们打开了网页,我们就可以获取网页上的任何东西

Selenium有很多元素筛选方法,通过class、id等等进行筛选

下面就是常见方法

但是还是最推荐用xpath

可以直接下图方法使用这个来获取这个元素的路径

但是我更喜欢自己手动找元素!

4.1、获取元素的实用方法

打开网页后,我们就需要和里面的元素进行交互,所以我们要获取

1、模糊匹配获取元素 & 联合多个样式

main_line_list = chromedriver.find_elements(By.XPATH, 
f"//span[@class='fancytree-title' and contains(@title, '干线')]")

这里既筛选了class中的内容,又筛选了这个span标签里面的文本信

其实,一般情况下,我们可以直接模糊匹配内容就足够了!

也就是直接使contains!!!所以这就是为什么建议使用xpath了

2、使用拉姆达表达式

这样可以更加直观的看出代码含义

element = WebDriverWait(chromedriver, timeout=10).
            until(lambda d: d.find_element(By.ID, "tree-input"))

3、加上睡眠时间,增加容错

当浏览器点击了一些东西之后,他需要加载或者跳转网页

所以我们需要让程序睡眠一下,增加容错

尤其是,我实习的那里,那些电脑都是老古董,时不时就抽风,卡顿...

    chrome_web_driver.chromedriver.find_element(By.XPATH, "//span[text()='重置密码']").click()
    time.sleep(2)

4、合理利用树形结构

有时候,我们定位一个元素,往往会有多个重复的元素

我们可以先获取他的祖先元素,在祖先元素的基础上,再进行获取!

chromedriver.find_element(By.ID, 'colid-1934886344377413')
.find_element(By.CLASS_NAME, "suffix-group")

4.2、获取网页元素失败怎么办?

1、确保4.1的方法都使用正确!!

可能是获取到了多个

确保使用正确的定位方式来定位元素。

可以采用4.1中的方法

2、检查我们的代码,获取的那个代码,是否有问题

看清楚元素是div还是span,还是<i>

我之前就是因为这个,在那里找了半天的错误

3、iframe的问题

网页中的iframe(内联框架)是页面中嵌套的独立文档。

在Selenium中,要与iframe中的元素进行交互,需要先切换到iframe上下文,然后才能执行操作。

定位iframe元素

iframe = driver.find_element_by_xpath("//iframe[@id='frame_id']")

切换到iframe上下文

driver.switch_to.frame(iframe)

执行在iframe中的操作

element_inside_iframe = driver.find_element_by_xpath("//button[@id='button_inside_iframe']")
element_inside_iframe.click()

切换回默认上下文

driver.switch_to.default_content()

如果iframe嵌套层级较深,你可能需要多次切换上下文来定位内部的iframe和元素。在处理复杂的页面结构时,建议先仔细分析页面结构,确保准确地切换到所需的iframe上下文。

4、网页跳转的问题

当我们进行了网页的一些操作时,会打开新的网页,这时候,我们还停留在原来的网页!

我们需要切换到新的网页里面进行操作的话,也得进行切换!!!

获取当前窗口句柄

current_window_handle = driver.current_window_handle

获取所有窗口句柄

all_window_handles = driver.window_handles

切换到新窗口句柄

for window_handle in all_window_handles:
    if window_handle != current_window_handle:
        driver.switch_to.window(window_handle)
        break

切换回原始窗口句柄(可选)

driver.switch_to.window(current_window_handle)

五、Selenium点击元素的方法

当我们可以获取元素后,我们往往需要进行操作,其中无法就是输入+点击

输入很简单,我们只需要3行代码

    input_element = chromedriver.find_element(By.ID, 'findSource').find_element(By.TAG_NAME, 'input')
    input_element.clear()
    input_element.send_keys('无人机')

为了避免有错误,在输入前最好先清空一下里面的内容

使用右键点击

canvas_element = chromedriver.find_element(By.TAG_NAME, 'canvas')
ActionChains(chromedriver).context_click(canvas_element).perform()

下面的都是左键的点击方法了

方法描述
click() 方法使用 Selenium 提供的 click() 方法直接触发元素的点击事件。
JavaScript 执行点击事件使用 driver.execute_script() 方法执行 JavaScript 代码,模拟触发点击事件。
ActionChains 类使用 ActionChains 类提供的方法模拟用户操作,包括点击操作。
send_keys(Keys.RETURN) 方法对于某些元素,可以使用 send_keys(Keys.RETURN) 方法模拟按下回车键,从而触发点击事件。
submit() 方法如果要点击的元素是一个表单中的提交按钮,可以直接使用 submit() 方法来提交表单,触发点击事件。
使用 JavaScript 修改元素属性通过执行 JavaScript 代码来修改元素的属性,例如将元素的 onclick 属性设置为 null,然后再点击该元素。
使用 pyautogui 或 Robot 类在某些情况下,可以使用 pyautogui 或 Robot 类来模拟鼠标点击,从而触发点击事件。

在 Selenium 中触发点击事件(最常用的三种方法)

1、使用 click() 方法:

这是最简单和最常用的方法。通过选中要点击的元素,然后使用 click() 方法来触发点击事件。
示例代码:

element = driver.find_element_by_id("element_id")
element.click()

2、使用 JavaScript 执行点击事件:

有时候使用 Selenium 的 click() 方法可能不够稳定,可以通过执行 JavaScript 代码来模拟点击事件。
示例代码:

element = driver.find_element_by_id("element_id")
driver.execute_script("arguments[0].click();", element)

3、使用 ActionChains 类:

ActionChains 类提供了模拟用户行为的方法,其中包括鼠标点击操作。
示例代码:

from selenium.webdriver.common.action_chains import ActionChains

element = driver.find_element_by_id("element_id")
ActionChains(driver).click(element).perform()

这些方法可以根据具体情况和需求选择合适的方式来触发点击事件。通常情况下,推荐优先使用 click() 方法,如果出现稳定性问题,可以尝试使用 JavaScript 执行点击事件或者 ActionChains 类来解决。


另外四种(不常用)

4、使用 send_keys(Keys.RETURN) 模拟回车键:

对于某些元素,可以使用 send_keys(Keys.RETURN) 方法来模拟按下回车键,从而触发点击事件。
示例代码:

element = driver.find_element_by_id("element_id")
element.send_keys(Keys.RETURN)

5、使用 submit() 方法提交表单:

如果要点击的元素是一个表单中的提交按钮,可以直接使用 submit() 方法来提交表单,触发点击事件。
示例代码:

form = driver.find_element_by_id("form_id")
form.submit()

6、使用 JavaScript 修改元素属性:

可以通过执行 JavaScript 代码来修改元素的属性,从而触发点击事件。例如,将元素的 onclick 属性设置为 null,然后再点击该元素。
示例代码:

element = driver.find_element_by_id("element_id")
driver.execute_script("arguments[0].setAttribute('onclick', 'null');", element)
element.click()

7、使用 Robot 类模拟物理点击:

在某些情况下,可以使用 Python 的 pyautogui 或 Java 的 Robot 类来模拟鼠标点击,从而触发点击事件。
示例代码(Python pyautogui):

import pyautogui

element = driver.find_element_by_id("element_id")
element_location = element.location
pyautogui.click(element_location['x'], element_location['y'])

这些方法可以根据具体情况和需求来选择合适的方式来实现点击事件。需要注意的是,每种方法都有其适用的场景和限制条件,选择时应根据具体情况进行权衡和判断。

六、Selenium+browsermob-proxy获取网络请求

为什么要获取网络请求,因为有一些数据是渲染到canvas里面的

导致我们从网页中的元素里面拿取不到!那么就只有通过抓请求了!!!

1. 下载browsermob-proxy.bat

Releases · lightbody/browsermob-proxy · GitHubA free utility to help web developers watch and manipulate network traffic from their AJAX applications. - Releases · lightbody/browsermob-proxyicon-default.png?t=N7T8https://links.jianshu.com/go?to=https%3A%2F%2Fgithub.com%2Flightbody%2Fbrowsermob-proxy%2Freleases要求jdk1.8以上

下载JDK,可以直接使用Java8安装!

java8安装教程:

java 8( jdk1.8u321)安装教程(超详细)_java8安装-CSDN博客

 2.安装python模块browsermob-proxy

 pip install browsermob-proxy

3、编写代码

import time  
  
from selenium import webdriver  
from browsermobproxy import Server  
  
# 启动 browsermob-proxy 服务器  
server = Server(r"D:\browsermob-proxy-2.1.4\bin\browsermob-proxy.bat")  
server.start()  
proxy = server.create_proxy()  
  
# 配置 Selenium WebDriver 使用代理  
proxy_address = "--proxy-server={0}".format(proxy.proxy)  
chrome_options = webdriver.ChromeOptions()  
chrome_options.add_argument(proxy_address)  
chrome_options.add_argument('--ignore-certificate-errors')  
driver = webdriver.Chrome(chrome_options=chrome_options)  
  
# 开始记录网络请求  
proxy.new_har("page")  
  
# 打开网页  
driver.get("https://baidu.com")  
time.sleep(3)  
# 获取捕获的网络请求  
har = proxy.har  
  
# 打印请求和响应内容  
for entry in har['log']['entries']:  
    request_url = entry['request']['url']  
    response = entry['response']  
    response_content = response  
    print("Request URL:", request_url)  
    print("Response Content:", response_content)  
time.sleep(3)  
# 关闭浏览器和 proxy 服务器  
driver.quit()  
server.stop()

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/665686.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

5.30 学习总

刷题记录(Codeforces Round 947 &#xff08;Div. 1 Div. 2&#xff09;B,C题)和Codeforces Round 948 &#xff08;Div. 2&#xff09;B题 一.B. 378QAQ and Mochas Array B. 378QAQ and Mochas Array time limit per test 1 second memory limit per test 256 megabytes in…

AI盒子在智慧加油站的应用

方案背景 为规范加油站作业&#xff0c;保障人民生命财产安全&#xff0c;《加油站作业安全规范》&#xff08;AQ 3010-2007&#xff09;中第五条规定&#xff1a;卸油作业基本要求&#xff0c;明确防静电、防雷电、防火、人员值守、禁止其他车辆及非工作人员进入卸油区。 痛点…

[羊城杯 2021]BabySmc

运行就是输入flag 不知道怎么跳过去的 这个应该就是smc加密的函数了 运行完这个函数才能继续往下 int __cdecl main(int argc, const char **argv, const char **envp) {__int64 v3; // rbx__int64 v4; // r12__int64 v5; // r13unsigned __int64 v6; // raxchar v7; // spcha…

迅狐跨境电商系统源码:技术栈与多端集成

随着全球化贸易的不断深入&#xff0c;跨境电商系统源码成为了连接不同国家和地区消费者与商家的重要桥梁。本文将探讨跨境电商系统源码的技术栈以及如何通过多端集成来提升用户体验。 技术栈概览 跨境电商系统源码的技术栈是构建高效、稳定平台的基础。以下是构建跨境电商系…

一份不知道哪里来的第十五届国赛模拟题

这是一个不知道来源的模拟题目&#xff0c;没有完全完成&#xff0c;只作代码记录&#xff0c;不作分析和展示&#xff0c;极其冗长&#xff0c;但里面有长按短按双击的复合&#xff0c;可以看看。 目录 题目代码底层驱动主程序核心代码关键&#xff1a;双击单击长按复合代码 …

七年之痒!一个 PHP 程序员职业生涯的自述

大家好&#xff0c;我是码农先森。 今年刚好是我毕业的第七个年头&#xff0c;在婚姻感情当中都有一种「七年之痒」的说法&#xff0c;这次我把这个词「七年之痒」用一次在我的职业生涯复盘上。七年前我从告别校园&#xff0c;踏入互联网编程行业&#xff0c;七年后我依旧在编…

FreeRtos进阶——中断的内部逻辑

中断与非中断API的区别 BaseType_t xQueueSendToBack(QueueHandle_t xQueue,const void *pvItemToQueue,TickType_t xTicksToWait); BaseType_t xQueueSendToBackFromISR(QueueHandle_t xQueue,const void *pvItemToQueue,BaseType_t *pxHigherPriorityTaskWok…

SpringBoot源码(自动装配、内嵌Tomcat)

文章目录 依赖管理pom依赖管理Web依赖自定义starter 一、WebMvcAutoConfiguration1.1 Filter1.2 Interceptor 二、源码解析2.1 SpringApplication2.1.1 构造方法1、填充webApplicationType2、自动装配Initializers3、自动装配Listeners 2.1.2 run(args) 2.2 SpringApplicationR…

实用软件分享---超级轻量级的强力卸载软件工具UninstallView_1.51

专栏介绍:本专栏主要分享一些实用的软件(Po Jie版); 声明1:软件不保证时效性;只能保证在写本文时,该软件是可用的;不保证后续时间该软件能一直正常运行;不保证没有bug;如果软件不可用了,我知道后会第一时间在题目上注明(已失效)。介意者请勿订阅。 声明2:本专栏的…

【OrangePi AIpro】从开箱到第一个AI应用开发

第一章 OrangePi AIpro介绍和开发环境搭建 1.1 OrangePi AIpro介绍 OrangePi AIpro(8T)采用昇腾AI技术路线&#xff0c;具体为4核64位处理器AI处理器&#xff0c;集成图形处理器&#xff0c;支持8TOPS AI算力&#xff0c;拥有8GB/16GB LPDDR4X&#xff0c;可以外接32GB/64GB/…

CANOE制造dll文件,以及应用dll文件

1、使用canoe自带的capl dll 2、然后使用Visual Studio 2022 打开项目 3、项目打开后修改下项目属性 4、修改capldll.cpp文件 4.1 添加的内容 void CAPLEXPORT far CAPLPASCAL appSum(long i, long j, long* s){*s i j;} {"sum", (CAPL_FARCALL)appSum, "…

FinalShell无法连接Linux

Linux使用Vmware会创建一个网络&#xff0c;让两个子网处于一个网关&#xff0c;这样就能在windows中连接Linux&#xff0c;只有在这种情况下才能FinalShell才能连接Linux

Redis 和 Mysql 如何保证两者数据一致性

文章目录 概述解决方案消息队列异步重试 基于 RocketMQ 的可靠性消息通信&#xff0c;来实现最终一致Canal 组件&#xff0c;监控 Mysql 中 binlog 的日志&#xff0c;把更新后的数据同步到 Redis 里面延时双删弱一致性和强一致性Canal详解 概述 在分布式系统中&#xff0c;保…

2024中国军民两用智能装备与通信技术产业展览会带你走进轻元素量子材料世界

在科技创新的浪潮中&#xff0c;北京怀柔科学城迎来了一场革命性的突破——世界首个轻元素量子材料平台正式启动运行。这一里程碑事件不仅彰显了中国在量子科学研究上的领先地位&#xff0c;也为全球科技界带来了一股新风潮。由北京大学领衔打造的这一平台&#xff0c;专注于轻…

[论文笔记]MemGPT: Towards LLMs as Operating Systems

引言 今天介绍一篇论文MemGPT: Towards LLMs as Operating Systems。翻过过来就是把LLM看成操作系统。 大语言模型已经在人工智能领域引起了革命性的变革&#xff0c;但受到有限上下文窗口的限制&#xff0c;在扩展对话和文档分析等任务中的效用受到了阻碍。为了能够利用超出…

免费生物蛋白质的类chatgpt工具助手copilot:小分子、蛋白的折叠、对接

参考: https://310.ai/copilot 可以通过自然语言通话晚上蛋白质的相关处理:生成序列、折叠等 应该是agent技术调用不同工具实现 从UniProt数据库中搜索和加载蛋白质。使用ESM Fold方法折叠蛋白质。使用310.ai基础模型设计新蛋白质。使用TM-Align方法比较蛋白质。利用Protei…

谁是镰刀谁是韭菜?程序交易与手动交易的博弈,靠技术还是靠运气

备受争议的话题&#xff0c;很多人认为程序化交易是在破坏市场的平衡&#xff0c;大量的程序交易订单可能会造成市场价格的异常波动&#xff0c;尤其是在高频交易未被监管时&#xff0c;程序化交易者占尽优势&#xff0c;来回收割。 而支持程序交易的人认为&#xff0c;市场是…

Java八股文:程序员的“面试经”还是技术壁垒?

Java八股文&#xff1a;程序员的“面试经”还是技术壁垒&#xff1f; “八股文”&#xff0c;在中国古代科举考试中&#xff0c;指的是一种程式化的文章写作格式&#xff0c;内容空洞&#xff0c;缺乏创新。而如今&#xff0c;这个词语被赋予了新的含义&#xff0c;用来形容技术…

python基础(习题、资料)

免费提取资料&#xff1a; 练习、资料免费提取。持续更新迅雷云盘https://pan.xunlei.com/s/VNz6kH1EXQtK8j-wwwz_c0k8A1?pwdrj2x# 本文为Python的进阶知识合辑&#xff0c;包括列表&#xff08;List&#xff09;、元组&#xff08;Tuple&#xff09;、字典&#xff08;Dic…

微信密码忘记了怎么找回?自助找回2个方法揭晓!

在微信的世界里&#xff0c;密码就像是我们通往个人世界的“钥匙”&#xff0c;一旦丢失&#xff0c;就仿佛被锁在了自己的门外。微信密码忘记了怎么找回&#xff1f;别担心&#xff0c;微信提供了多种自助找回密码的方法&#xff0c;让我们一起来揭秘这些找回密码的秘诀吧&…