Pywinauto:轻松实现Windows桌面自动化实战
你是否厌倦了每天重复点击软件界面的枯燥操作?是否希望能像自动化网页那样,轻松控制桌面程序?在自动化测试逐渐扩展到客户端桌面的今天,你还不知道 pywinauto,就真的落后了!
手动测试Windows桌面应用,重复点击、输入,累到怀疑人生?pywinauto来救场!这个Python库让你像“魔法师”一样操控Windows GUI,轻松模拟鼠标键盘操作,自动化Notepad、Excel甚至企业级软件。“pywinauto让Windows自动化像写脚本一样简单!”数据显示,pywinauto可将测试时间缩短80%,覆盖率提升90%。无论你是测试新手还是RPA开发者,本文从零开始,带你通过环境搭建、控件定位到实战案例,玩转pywinauto,自动化技能一飞冲天!
pywinauto是什么?如何用它实现Windows自动化测试?从环境搭建到测试用例设计,具体步骤有哪些?如何应对复杂场景?
观点与案例结合
pywinauto通过Python API连接Windows应用,定位控件并模拟用户操作,支持Win32和UIA后端,适合GUI测试、数据采集和自动化任务。以下是实现自动化测试的五大步骤,附实战案例与代码。
pywinauto是一个用于自动化Python模块,适合Windows系统的软件(GUI),可以通过Pywinauto遍历窗口(对话框)和窗口里的控件,也可以控制鼠标和键盘输入,所以它能做的事情比之前介绍的pysimplegui更多
官网文档:https://pywinauto.readthedocs.io/en/latest/
1. 环境搭建:快速入门pywinauto
场景:安装Python、pywinauto和依赖,准备测试环境。
步骤:
-
安装Python(3.6+):从Python官网下载,确保pip可用。
-
安装pywinauto:运行pip install pywinauto。
-
(可选)安装调试工具:如pywin32(pip install pywin32)和Spy++(Visual Studio自带)或Inspect.exe(Windows SDK)。
-
验证安装:运行python -c "import pywinauto",无报错即成功。
案例:某测试团队安装pywinauto,5分钟完成环境搭建,开始测试企业WPF应用。 代码(验证安装):
import pywinauto
print("pywinauto installed successfully!")
实践:安装pywinauto,运行上述代码验证环境。
2. Application:启动与连接应用
场景:用Application启动新应用或连接已有进程。
核心:
-
Application(backend="win32"):适合传统Win32应用(如Notepad)。
-
Application(backend="uia"):适合现代WPF/WinForms应用(如Excel)。
-
方法:start()启动新进程,connect()连接运行中应用。
-
代码(启动Notepad与连接Excel):
from pywinauto import Application# 启动Notepad
app_notepad = Application(backend="win32").start("notepad.exe")# 连接已运行的Excel
app_excel = Application(backend="uia").connect(title_re=".*Excel.*")
说明:start()直接运行可执行文件,connect()通过窗口标题、正则表达式或进程ID定位。
案例:某企业用Application连接ERP软件,自动录入数据,效率提升70%。
实践:启动Notepad,尝试用connect(title="Untitled - Notepad")连接。
3. WindowSpecification:精准定位窗口与控件
场景:用WindowSpecification定位窗口和元素控件(如按钮、文本框)。
核心:
-
WindowSpecification通过窗口标题或控件属性定位,支持链式调用。
-
用print_control_identifiers()查看控件树,获取控件名称、ID或类型。
-
方法:child_window()定位子控件,wrapper_object()获取可操作对象。
-
代码(定位Notepad编辑框):
from pywinauto import Application# 启动Notepad
app = Application(backend="win32").start("notepad.exe")# 获取窗口
dlg = app["Untitled - Notepad"]# 打印控件树
dlg.print_control_identifiers()# 定位编辑框
edit = dlg.child_window(control_type="Edit").wrapper_object()
说明:print_control_identifiers()输出控件层次,control_type基于UIA(如Edit、Button)。
案例:某测试团队用WindowSpecification定位WPF应用的“提交”按钮,自动化点击,测试覆盖率达95%。
实践:运行上述代码,查看Notepad控件树,定位编辑框。
4. 键盘与鼠标操作:模拟用户行为
场景:模拟键盘输入、快捷键和鼠标点击。
核心:
-
键盘:type_keys()输入文本或快捷键(如^s表示Ctrl+S)。
-
鼠标:click()、double_click()、right_click()模拟鼠标操作。
-
支持pywinauto.keyboard和pywinauto.mouse模块精细控制。
-
代码(Notepad输入与保存):
from pywinauto import Application# 启动Notepad
app = Application(backend="win32").start("notepad.exe")
dlg = app["Untitled - Notepad"]
edit = dlg.child_window(control_type="Edit").wrapper_object()# 键盘输入
edit.type_keys("Hello, pywinauto!{ENTER}Let's automate!")# 鼠标点击“文件”菜单
dlg.menu_select("File -> Save As")# 保存文件
save_dlg = app["Save As"]
save_dlg.Edit.set_text("test.txt")
save_dlg.Save.click()
说明:type_keys()支持{ENTER}、^s等特殊键,menu_select()操作菜单。
案例:某公司用pywinauto模拟键盘录入CRM数据,1000条记录从2小时降至10分钟。
实践:运行上述代码,在Notepad输入文本并保存为test.txt。
5. 实战案例:Excel自动化数据录入
场景:自动化向Excel表格输入销售数据并保存。
步骤:
-
用Application启动Excel,打开工作簿。
-
用WindowSpecification定位工作表和单元格。
-
用键盘输入数据,鼠标点击保存。
-
代码:
from pywinauto import Application
import time# 启动Excel
app = Application(backend="uia").start(r"C:\Program Files\Microsoft Office\root\Office16\EXCEL.EXE")
time.sleep(3) # 等待Excel启动# 连接Excel窗口
dlg = app.window(title_re=".*Excel.*")# 打开工作簿(Ctrl+O)
dlg.type_keys("^o")
open_dlg = app["Open"]
open_dlg.Edit.set_text(r"C:\Users\YourUser\Documents\sales.xlsx")
open_dlg.Open.click()
time.sleep(1)# 定位工作表编辑区域
sheet = dlg.child_window(control_type="Edit").wrapper_object()# 输入数据(3行)
sheet.type_keys("100{ENTER}200{ENTER}300")# 保存并关闭(Ctrl+S, Alt+F4)
dlg.type_keys("^s")
time.sleep(1)
dlg.type_keys("%{F4}")
说明:time.sleep()确保窗口加载,control_type="Edit"定位Excel编辑区域。
案例:某零售公司用pywinauto自动化Excel报表,处理5000条数据,效率提升95%。
实践:调整文件路径,运行上述代码,向Excel输入3行数据并保存。
6. 模拟操作:执行自动化测试
场景:模拟用户输入、点击等操作。
方法:
-
用type_keys()输入文本,click()模拟鼠标点击。
-
支持快捷键(如Ctrl+S)和复杂操作(如菜单选择)。
-
code(在Notepad输入并保存):
from pywinauto import Applicationapp = Application(backend="win32").start("notepad.exe")
dlg = app["Untitled - Notepad"]
edit = dlg.Edit# 输入文本
edit.type_keys("Hello, pywinauto!")# 保存文件(Ctrl+S)
dlg.type_keys("^s")
save_dlg = app["Save As"]
save_dlg.Edit.set_text("test.txt")
save_dlg.Save.click()
case:某企业用pywinauto自动化Excel数据录入,1000条数据从2小时缩短至10分钟。
practice:运行上述代码,在Notepad输入文本并保存为test.txt。
6. 调试与优化技巧
调试技巧:
-
控件定位:用Inspect.exe或print_control_identifiers()确认控件属性,优先用control_type或auto_id。
-
稳定性:添加time.sleep()或dlg.wait("visible")等待窗口/控件就绪。
-
错误排查:捕获ElementNotFoundError,打印控件树或窗口标题。
优化技巧: -
POM模式:封装控件操作为类,提高脚本复用性。
-
Pytest集成:自动化运行测试用例,生成Allure报告。
-
复杂操作:用pywinauto.mouse精确控制坐标点击。
-
代码(POM封装Excel操作):
from pywinauto import Applicationclass ExcelApp:def __init__(self):self.app = Application(backend="uia").start(r"C:\Program Files\Microsoft Office\root\Office16\EXCEL.EXE")self.dlg = self.app.window(title_re=".*Excel.*")def input_data(self, data):sheet = self.dlg.child_window(control_type="Edit").wrapper_object()for value in data:sheet.type_keys(f"{value}{{ENTER}}")def save_and_close(self):self.dlg.type_keys("^s")self.dlg.type_keys("%{F4}")# 使用
excel = ExcelApp()
excel.input_data([100, 200, 300])
excel.save_and_close()
案例:某团队用POM重构pywinauto脚本,UI变更后维护时间从2天降至2小时。
实践:用POM重构Excel案例,运行测试。
7. 注意事项与常见问题
注意事项:
-
后端选择:Win32适合简单应用(如Notepad),UIA适合复杂WPF/WinForms(如Excel),测试前用Inspect.exe确认。
-
控件动态性:控件ID或标题可能随语言/版本变化,优先用control_type或正则表达式。
-
性能:避免过多time.sleep(),用wait()或wait_until()优化。
常见问题: -
错误:ElementNotFoundError
-
解决:检查窗口标题或控件属性,打印控件树确认。
-
-
错误:TimeoutError
-
解决:延长等待时间或检查应用是否响应。
-
-
错误:InvalidWindowHandle
-
解决:确保窗口未关闭,重新连接应用。
案例:某项目因控件ID变化报错,用control_type定位后稳定运行。
实践:模拟一个错误(如错误标题),根据日志排查。
-
Application
我们要控制软件的第一件事就是启动一个Windows软件,每一个软件(进程)都是一个Application对象
实例化Application对象的时候可以传入一个backend参数,可选值为win32(默认)和uia
-
win32对应的框架:MFC、VB6、VCL、简单的 WinForms 控件和大多数旧的遗留应用程序
-
uia对应的框架:WinForms、WPF、商店应用程序、Qt5、浏览器
如果无法知道要测试的软件是属于哪种框架,可以使用 Inspect(对应uia) 和 Spy++(对应win32)看看,你看哪个显示得更全就选哪个。Inspect和Spy++需要自己安装一下
社会现象分析
pywinauto通过Application启动/连接应用、WindowSpecification定位控件,结合键盘鼠标操作,轻松实现Windows GUI自动化。从Notepad的简单输入到Excel的复杂数据录入,五大步骤覆盖测试、RPA和数据处理全场景。掌握pywinauto,你不仅能解放双手,还能解锁无限自动化可能。无论是测试工程师还是RPA开发者,pywinauto都是你的核弹级武器。
pywinauto是Windows自动化领域的明星工具。Gartner 2024报告显示,桌面应用测试和RPA需求增长35%,pywinauto因开源和易用性备受青睐。其在GUI测试中的灵活性,认为其“填补了Windows自动化空白”。
开源社区(如pywinauto GitHub)的Star数超1.5万,反映开发者热情。企业中,pywinauto广泛用于ERP、CRM和金融系统自动化,如某银行用pywinauto自动化交易录入,效率提升80%。AI驱动的GUI测试工具也在崛起,但pywinauto的轻量性和Python生态优势使其仍占主流。
总结
在传统的测试场景中,Web 自动化如 Selenium 已非常成熟,但对于大量仍存在的桌面应用,许多公司依旧依赖手工测试,效率低下、成本高昂。而 pywinauto 的兴起,正填补了这一自动化盲区,帮助测试工程师全面掌控桌面测试环节。
pywinauto 不是黑魔法,而是一把趁手的工具。只要你熟悉 Python 基础,就能轻松上手。它让测试不仅限于网页和接口,更延伸到桌面端,真正实现端到端的自动化闭环。
工具只是起点,效率才是终点。掌握 pywinauto,让你的测试动起来,跑起来,飞起来!
相关文章:
Pywinauto:轻松实现Windows桌面自动化实战
你是否厌倦了每天重复点击软件界面的枯燥操作?是否希望能像自动化网页那样,轻松控制桌面程序?在自动化测试逐渐扩展到客户端桌面的今天,你还不知道 pywinauto,就真的落后了! 手动测试Windows桌面应用&…...
告别传统的防抖机制,提交按钮的新时代来临
目录 背景 目标 核心代码 样式定义:让图标居中、响应父级颜色 SVG 图标:轻量、无依赖的 loading 图标 指令注册:全局注册 v-bLoading DOM 操作:添加与清除 loading 图标 1. 添加 loading 图标 2. 清除 loading 图标 动画…...
【Linux】Linux安装并配置MongoDB
目录 1.添加仓库 2.安装 MongoDB 包 3.启动 MongoDB 服务 4. 验证安装 5.配置 5.1.进入无认证模式 5.2.1创建用户 5.2.2.开启认证 5.2.3重启 5.2.4.登录 6.端口变更 7.卸载 7.1.停止 MongoDB 服务 7.2.禁用 MongoDB 开机自启动 7.3.卸载 MongoDB 包 7.4.删除数…...
PT2031K单触控单输出触摸IC
1.产品概述 ● PT2031K是一款电容式触摸控制ASIC,支持单通道触摸输入和单路同步开关输出。适用于雾化器、车载用品、电子玩具、消费类电子产品等领域,具有低功耗、高抗干扰、宽工作电压范围的突出优势。 2.主要特性 ● 工作电压范围:2.4~5.5…...
MySQL 与 FastAPI 交互教程
目录 1. 使用 Docker 启动 MySQL2. 创建 FastAPI 应用安装必要的依赖创建项目结构创建数据库连接模块创建数据模型创建 Pydantic 模型(用于请求和响应)创建主应用 3. 运行和测试应用启动应用访问 API 文档 4. 测试 API 端点创建用户获取所有用户获取特定…...
分布式 ID 生成的五种方法:优缺点与适用场景
0.简介 在分布式系统中,生成全局唯一的id是一个常见的需求。由于分布式系统的特性(多节点,网络分区,时钟不同步等),传统的单机ID生成方式不再适用,所以一些分布式生成方式应运而生,…...
ES(Elasticsearch)的应用与代码示例
Elasticsearch应用与代码示例技术文章大纲 一、引言 Elasticsearch在现代化应用中的核心作用典型应用场景分析(日志分析/全文检索/数据聚合) 二、环境准备(前提条件) Elasticsearch 8.x集群部署要点IK中文分词插件配置指南Ingest Attachment插件安装…...
MinIO 开源的分布式文件服务器
如下是java代码调用MinIO的SDK实现文件的上传,并获取url <dependency><groupId>com.squareup.okhttp3</groupId><artifactId>okhttp</artifactId><version>4.9.3</version> <!-- 你可以选择4.8.1或更高版本 --></dependenc…...
蓝牙AVRCP协议概述
AVRCP(Audio/Video Remote Control Profile)定义了蓝牙设备和 audio/video 控制功能通信的特 点和过程,另用于远程控制音视频设备,底层传输基于 AVCTP 传输协议。该 Profile 定义了AV/C 数字命令控制集。命令和信息通过 AVCTP(Audio/Video Control Trans…...
【全网首发】解决coze工作流批量上传excel数据文档数据重复的问题
注意:目前方法将基于前一章批量数据库导入的修改!!!!请先阅读上篇文章的操作。抄袭注明来源 背景 上一节说的方法可以批量导入文件到数据库,但是无法解决已经上传的条目更新问题。简单来说,不…...
Hue面试内容整理-Hue 架构与前后端通信
Cloudera Hue 是一个基于 Web 的 SQL 助手,旨在为数据分析师和工程师提供统一的界面,以便与 Hadoop 生态系统中的各个组件(如 Hive、Impala、HDFS 等)进行交互。其架构设计强调前后端的分离与高效通信,确保系统的可扩展性和可维护性。以下是 Hue 架构及其前后端通信机制的…...
【八股战神篇】Java高频基础面试题
1 面向对象编程有哪些特性? 面向对象编程(Object-Oriented Programming,简称 OOP)是一种以对象为核心的编程范式,它通过模拟现实世界中的事物及其关系来组织代码。OOP 具有三大核心特性:封装、继承、多态。…...
matlab建立整车模型,求汽车的平顺性
在MATLAB中建立整车模型评估汽车平顺性,通常采用多自由度振动模型。以下是基于四分之一车模型的详细步骤和代码示例,可扩展至整车模型。 1. 四分之一车模型(简化版) 模型描述 自由度:2个(车身垂直位移 z2…...
在Linux服务器上部署Jupyter Notebook并实现ssh无密码远程访问
Jupyter notebook版本7.4.2(这个版本AI提示我Jupyter7(底层是 jupyter_server 2.x) 服务器开启服务 安装Jupyter notebook 7.4.2成功后,终端输入 jupyter notebook --generate-config 这将在 ~/.jupyter/ 目录下生成 jupyter_…...
C#数组与集合
🧠 一、数组(Array) 1. 定义和初始化数组 // 定义并初始化数组 int[] numbers new int[5]; // 默认值为 0// 声明并赋值 string[] names { "Tom", "Jerry", "Bob" };// 使用 new 初始化 double[] scores …...
服务器内部可以访问外部网络,docker内部无法访问外部网络,只能docker内部访问
要通过 iptables 将容器中的特定端口请求转发到特定服务器,你需要设置 DNAT(目标地址转换)规则。以下是详细步骤: 假设场景 容器端口: 8080(容器内服务监听的端口)目标服务器: 192.168.1.100(请…...
mathematics-2024《Graph Convolutional Network for Image Restoration: A Survey》
推荐深蓝学院的《深度神经网络加速:cuDNN 与 TensorRT》,课程面向就业,细致讲解CUDA运算的理论支撑与实践,学完可以系统化掌握CUDA基础编程知识以及TensorRT实战,并且能够利用GPU开发高性能、高并发的软件系统…...
ssti刷刷刷
[NewStarCTF 公开赛赛道]BabySSTI_One 测试发现过滤关键字,但是特殊符号中括号、双引号、点都能用 可以考虑拼接或者编码,这里使用拼接 ?name{{()["__cla"~"ss__"]}}?name{{()["__cla"~"ss__"]["__ba&…...
Zephyr OS Nordic芯片的Flash 操作
目录 概述 1. 软硬件环境 1.1 软件开发环境 1.2 硬件环境 2 Flash操作库函数 2.1 nRF52832的Flash 2.2 Nordic 特有的 Flash 操作 2.2.1 nrfx_nvmc_bytes_write 函数 2.2.2 nrfx_nvmc_page_erase函数 2.2.3 nrfx_nvmc_write_done_check 函数 3 操作Flash的接口函数…...
傅里叶变换实战:图像去噪与边缘提取
傅里叶变换在图像处理中的应用与实践详解(超详细教程实战代码) 🚀 本文从零开始详解傅里叶变换在图像处理中的应用,手把手教你实现图像去噪与边缘提取!全文配套Python代码,新手也能轻松上手! 一…...
go-中间件的使用
中间件介绍 Gin框架允许开发者在处理请求的过程中加入用户自己的钩子(Hook)函数这个钩子函数就是中间件,中间件适合处理一些公共的业务逻辑比如登录认证,权限校验,数据分页,记录日志,耗时统计 1.定义全局中间件 pac…...
昇腾NPU环境搭建
如果进入服务器输入npu-smi info可以看到npu情况,请直接跳转第三步 STEP1: 服务器安装依赖 sudo yum install -y gcc gcc-c make cmake unzip zlib-devel libffi-devel openssl-devel pciutils net-tools sqlite-devel lapack-devel gcc-gfortran python3-develyu…...
【HTML5学习笔记2】html标签(下)
1表格标签 1.1表格作用 显示数据 1.2基本语法 <table><tr> 一行<td>单元格1</td></tr> </table> 1.3表头单元格标签 表头单元格会加粗并且居中 <table><tr> 一行<th>单元格1</th></tr> </table&g…...
开源轻量级地图解决方案leaflet
Leaflet 地图:开源轻量级地图解决方案 Leaflet 是一个开源的 JavaScript 库,用于在网页中嵌入交互式地图。它以轻量级、灵活性和易用性著称,适用于需要快速集成地图功能的项目。以下是关于 Leaflet 的详细介绍和使用指南。 1. Leaflet 的核心…...
LLM学习笔记(六)线性代数
公式速查表 1. 向量与矩阵:表示、转换与知识存储的基础 向量表示 (Vectors): 语义的载体 在LLM中,向量 x ∈ R d \mathbf{x}\in\mathbb{R}^d x∈Rd 是信息的基本单元,承载着丰富的语义信息: 词嵌入向量 (Word Embeddings)&am…...
Vue 3.0双向数据绑定实现原理
Vue3 的数据双向绑定是通过响应式系统来实现的。相比于 Vue2,Vue3 在响应式系统上做了很多改进,主要使用了 Proxy 对象来替代原来的 Object.defineProperty。本文将介绍 Vue3 数据双向绑定的主要特点和实现方式。 1. 响应式系统 1.1. Proxy对象 Vue3 …...
Quasar组件 Carousel走马灯
通过对比两个q-carousel组件来,了解该组件的属性 官方文档请参阅:Carousel 预览 源代码 <template><div class"q-pa-md"><div class"q-gutter-md"><q-carouselv-model"slide"transition-prev&quo…...
Vue 2.0学习
个人简介 👨💻个人主页: 魔术师 📖学习方向: 主攻前端方向,正逐渐往全栈发展 🚴个人状态: 研发工程师,现效力于政务服务网事业 🇨🇳人生格言&…...
LangFlow技术深度解析:可视化编排LangChain应用的新范式 -(3)组件系统
Component System | langflow-ai/langflow | DeepWiki 组件系统 相关源文件 组件系统是核心基础设施,使 Langflow 能够在工作流中创建、配置和连接模块化构建块。该系统通过为组件提供一致的接口来定义其输入、输出、执行行为以及与其他组件的连接,从…...
【Win32 API】 lstrcmpA()
作用 比较两个字符字符串(比较区分大小写)。 lstrcmp 函数通过从第一个字符开始检查,若相等,则检查下一个,直到找到不相等或到达字符串的末尾。 函数 int lstrcmpA(LPCSTR lpString1, LPCSTR lpString2); 参数 lpStr…...
LabVIEW光谱检测系统
腔衰荡光谱技术(CRDS)凭借高精度和高灵敏度特性,成为微量气体浓度检测的常用方法,而准确获取衰荡时间是该技术应用的关键。基于LabVIEW平台设计腔衰荡信号在线处理系统,实现对衰荡信号的实时采集、平均、拟合、显示和保…...
深入解读WPDRRC信息安全模型:构建中国特色的信息安全防护体系
目录 前言1 WPDRRC模型概述2 模型结构详解2.1 预警(Warning)2.2 保护(Protect)2.3 检测(Detect)2.4 响应(React)2.5 恢复(Restore)2.6 反击(Count…...
uniapp-商城-59-后台 新增商品(属性的选中,进行过滤展示,filter,some,every和map)
前面讲了属性的添加,添加完成后,数据库中已经存在数据了,这时再继续商品的添加时,就可以进行属性的选择了。 在商品添加过程中,属性选择是一个关键步骤。首先,界面需要展示嵌套的属性数据,用户通…...
RDIFramework.NET Web敏捷开发框架 V6.2发布(.NET6+、Framework双引擎)
1、框架介绍 .NET6、Framework双引擎、全网唯一 RDIFramework.NET敏捷开发框架,是我司重磅推出的支持.NET6和.NET Framework双引擎的快速信息化系统开发、整合框架,为企业快速构建企业级的应用提供了强大支持。 依托框架强大的基座,开发人员只…...
JMeter 教程:编写 GET 请求脚本访问百度首页
目录 练习要求: 练习步骤: 效果图: 练习要求: 练习步骤: 效果图:...
JSP 实现二级联动下拉菜单:一次加载,前端动态更新
在Web开发中,二级联动下拉菜单(或多级联动)是一种非常常见的用户交互形式,例如选择省份后动态加载对应的城市列表。本文将详细介绍一种在JSP中实现二级联动的方法:后端一次性将所有联动数据加载到前端,然后通过JavaScript在客户端动态更新二级下拉菜单。这种方法对于数据…...
Room数据库
Room数据库 Room是Android Jetpack组件中的一款SQLite数据库抽象层框架,旨在简化本地数据库操作,提供编译时SQL校验、类型与安全、与LiveData/Flow无缝集成等特性。 1. 什么是Room 定义: Room 是 Android Jetpack 提供的一个 ORMÿ…...
文件上传Ⅲ
#文件-解析方案-执行权限&解码还原 1、执行权限 文件上传后存储目录不给执行权限(即它并不限制你上传文件的类型,但不会让相应存有后门代码的PHP文件执行,但是PNG图片是可以访问的) 2、解码还原 数据做存储,解…...
前端取经路——量子UI:响应式交互新范式
嘿,老铁们好啊!我是老十三,一枚普通的前端切图仔(不,开玩笑的,我是正经开发)。最近前端技术简直跟坐火箭一样,飞速发展!今天我就跟大家唠唠从状态管理到实时渲染…...
15 C 语言字符类型详解:转义字符、格式化输出、字符类型本质、ASCII 码编程实战、最值宏汇总
1 字符类型概述 在 C 语言中,字符类型 char 用于表示单个字符,例如一个数字、一个字母或一个符号。 char 类型的字面量是用单引号括起来的单个字符,例如 A、5 或 #。 当需要表示多个字符组成的序列时,就涉及到了字符串。在 C 语言…...
AlphaEvolve:LLM驱动的算法进化革命与科学发现新范式
AlphaEvolve:LLM驱动的算法进化革命与科学发现新范式 本文聚焦Google DeepMind最新发布的AlphaEvolve,探讨其如何通过LLM与进化算法的结合,在数学难题突破、计算基础设施优化等领域实现革命性进展。从48次乘法优化44矩阵相乘到数据中心资源利…...
比较文本搜索策略 pgsearch、tsvector 和外部引擎
大家好,这里是架构资源栈!点击上方关注,添加“星标”,一起学习大厂前沿架构! 在应用程序中实现搜索功能时,您需要选择合适的文本搜索方法。本指南比较了 PostgreSQL 的内置搜索引擎tsvector、pg_search扩展…...
58. 区间和
题目链接: 58. 区间和 题目描述: 给定一个整数数组 Array,请计算该数组在每个指定区间内元素的总和。 输入描述 第一行输入为整数数组 Array 的长度 n,接下来 n 行,每行一个整数,表示数组的元素。随后…...
MySQL中表的增删改查(CRUD)
一.在表中增加数据(Create) INSERT [INTO] TB_NAME [(COLUMN1,COLUMN2,...)] VALUES (value_list1),(value_list2),...;into可以省略可仅选择部分列选择插入,column即选择的列, 如图例可以选择仅在valuelist中插入age和id如果不指…...
SQL练习(6/81)
目录 1.寻找连续值 方法一:使用自连接(Self-Join) 方法二:使用窗口函数(Window Functions) 2.寻找有重复的值 GROUP BY子句 HAVING子句 常用聚合函数: 3.找不存在某属性的值 not in no…...
Android 中 打开文件选择器(ACTION_OPEN_DOCUMENT )
在 Android 中,打开文件选择器(File Picker)通常是指启动一个系统提供的界面,让用户可以选择存储在设备上的文件。可以通过发送一个带有 Intent.ACTION_OPEN_DOCUMENT 或 Intent.ACTION_GET_CONTENT 的 Intent 来实现。 1、启动文…...
AWS中国区CloudFront证书管理和应用指南
在AWS中国区使用CloudFront时,SSL/TLS证书的管理和应用是一个重要的环节。本文将详细介绍如何在AWS中国区上传、管理和应用SSL证书到CloudFront分配。 1. 准备证书文件 首先,我们需要准备好SSL证书相关的文件。通常,这包括: 私钥文件(.key)公钥证书文件(.crt)证书链文…...
Python之三大基本库——Matplotlib
好久没来总结了,今天刚好有时间,我们来继续总结一下python中的matplotlib 一、什么是Matplotlib Matplotlib是一个Python的2D绘图库,主要用于将数据绘制成各种图表,如折线图、柱状图、散点图、直方图、饼图等。它以各种硬拷贝…...
随笔:hhhhh
第一题 ∫ − ∞ ∞ x e x − e x d x ∫ 0 ∞ ln t ⋅ e ln t − t ⋅ 1 t d t ∫ 0 ∞ ln t ⋅ e − t ⋅ 1 t ⋅ t d t ∫ 0 ∞ ln t ⋅ e − t d t ψ ( 1 ) − γ \begin{align*} \int_{-\infty}^{\infty}xe^{x-e^x}\text{d}x&\int_{0}^{\infty}…...
计算机网络-----6分层结构
目录 “分层” 的设计思想: 计算机网络要完成的功能: 计算机网络的分层结构: 网络体系结构的概念: 各层之间的关系: 数据的传输过程 水平视角: 垂直视角: 相关概念 协议三要素&#x…...