21.Excel自动化:如何使用 xlwings 进行编程

一 将Excel用作数据查看器

使用 xlwings 中的 view 函数。

1.导包

import datetime as dt
import xlwings as xw
import pandas as pd
import numpy as np

2.view 函数

创建一个基于伪随机数的DataFrame,它有足够多的行,使得只有首尾几行会被显示。

df = pd.DataFrame(data=np.random.randn(100, 5),columns=[f"Trial {i}" for i in range(1, 6)])
print(df)

xw.view(df)

view 函数可以接受所有常见的 Python 对象,包括数字、字符串、列表、字典、元组、NumPy 数组和 pandas DataFrame。

在默认情况下,它会打开一个新的工作簿,然后将对象粘贴到第一张工作表的 A1 单元格。

不必每次都打开一个新的工作簿,你也可以通过为 view 函数提供一个 xlwings sheet 对象作为第二个参数来重复利用同一个工作簿文件:xw.view(df, mysheet)。

自动打开,未展示完全。 


二 xlwings 的使用方法

1.xw.Book() 的不同用法

1.xw.Book():创建新工作簿

 

wb = xw.Book() 和 wb = app.books.add() 都是新建一个工作簿,有什么区别?

在 xlwings 中,xw.Book() 和 app.books.add() 都可以用于创建新工作簿,但它们在底层实现和使用场景上有以下区别。

xw.Book():如果没有活动的Excel实例,它会启动一个新的,然后新建一个工作簿。如果有活动的实例,比如用户已经手动打开了Excel,那么它会在这个实例中新建工作簿。无需显式创建 App 对象,适合快速操作。

app.books.add():需要先有一个app对象,通过xw.App()创建。在指定的 app 实例中新建工作簿。适合需要同时操作多个 Excel 实例或工作簿的场景。

xw.Book()更自动化,适合简单场景;app.books.add()更明确,适合需要精细管理的情况。

补充:如果你在两个 Excel 实例中打开了同一个工作簿,或者想要指定某个 Excel 实例打开某个工作簿,就不能再使用 xw.book 了。此时需要使用 books 集合。

.books方法

xw.apps[key].books表示 Excel 实例中所有打开的工作簿集合。

访问工作簿:

通过索引:app.books[0] 获取第一个工作簿。

通过名称:app.books['Book1.xlsx'] 按名称获取。

myapp 代表一个 xlwings app 对象。(myapp=xw.App())如果将 myapp.books 替换成 xw.books,则 xlwings 会使用活动的 app。

2.xw.Book("Book1"):引用未保存的未命名工作簿

 xw.Book() 和 xw.Book("Book1") 的区别?

xw.Book():创建一个全新的 Excel 工作簿。

如果当前没有打开的 Excel 实例,xlwings 会自动启动一个。新工作簿默认命名为 Book1(如果未指定其他名称)。该工作簿不会自动保存,需手动调用 .save() 方法。

xw.Book("Book1"):尝试打开已存在的名为 "Book1" 的工作簿。

如果名为 "Book1" 的工作簿已打开,直接返回该工作簿的引用。如果名为 "Book1" 的工作簿未打开但存在(即文件存在于磁盘),xlwings 会打开它。如果文件不存在,会抛出 FileNotFoundError

3.xw.Book("Book1.xlsx"):引用已保存的文件 

路径也可以是绝对路径。

 4.xw.books.active:获取活动工作簿

返回当前 Excel 实例中活动的工作簿对象,直接获取用户当前正在操作的 Excel 工作簿对象。

2.xw.sheets[ ]访问工作表集合

返回工作簿中所有工作表的集合(类似列表)。

1.通过名称或索引访问特定工作表

 

2.遍历所有工作表

3.添加工作表

4.删除工作表

5.检查工作表是否存在

3.xw.range()的不同用法

.range方法是用来操作Excel单元格区域的。

xlwings 的 range 可接受的字符串格式:

1.对单个单元格

1.通过单元格名字操作单元格

补充:.value方法。

.value 是 Range 对象的属性。

读取:

cell_value = sheet.range("A1").value
print(cell_value)

写入:

sheet.range("A1").value = "New Value"

sheet1.range("A1").value = [[1, 2], [3, 4]] 这行代码是什么意思,A1这一个单元格里面的数据是[1, 2], [3, 4]吗?

自动扩展写入范围:虽然你指定了 A1 这个单个单元格,但当你给一个单元格赋值一个二维列表(如 [[1,2], [3,4]])时,xlwings 会自动将数据扩展到相邻的单元格区域。数据会被写入到 A1:B2 的区域。这个A1相当于是指定从A1单元格开始写入数据而不是写入A1单元格。赋予二维列表(如 [[1,2], [3,4]]),xlwings 会将其视为多行多列的数据,并自动扩展写入到连续的单元格区域。

2.通过行列索引操作

2.对多个单元格(范围)

1.命名范围操作

2.批量操作整行/整列

补充:索引和切片。

3.公式操作

4.多区域操作

3.range 对象的 options 方法

对应:5.Pandas :DataFrame 的使用——数据操作→9.将 DataFrame 写入 Excel

range.options() 方法,是用于动态控制 Excel 数据读写时的值处理方式的。只有在调用 value 属性时,options 的设置才会生效。

options() 本身不会立即处理数据,它只是定义了一组规则。当调用 .value 时,xlwings 会根据 options 的规则,对 range 区域的数据进行处理,返回结果。

myrange 是一个 xlwings range 对象:

options() 用于定义读取或写入数据时,值的转换规则。

常见的选项包括:

convert:控制数据类型转换(如将 Excel 中的数字文本转为 Python 的整数)。

dates:处理日期格式(如将 Excel 的日期序列转为 Python 的 datetime 对象)。

numbers:控制数字的解析方式(如科学计数法、千分位分隔符)。

补充:convert 参数可以接受的值。

4.对 sheet 对象进行索引和切片来获得 range 对象

补充:对 sheet 对象进行索引 / 切片和使用range 对象之间的区别。

sheet 对象在 xlwings 中代表 Excel 的工作表。用户可能通过sheet[行, 列]或者sheet[:行, :列]这样的索引或切片方式来操作单元格。而range对象则是通过sheet.range("A1")或者sheet.range("A1:B2")。

 

5.从 0 开始的索引和从 1 开始的索引的说明

作为一个 Python 包,只要你通过 Python 的索引或切片语法(通过方括号)访问元素,xlwings 就始终使用从 0 开始的索引。但是 xlwings 的 range 对象使用的是从 1 开始的行列索引。那么可以使用 sheet[row_selection, column_selection] 语法。

6.xw.name()和 xw.fullname()

xw.name:返回 Excel 应用程序的简短名称(通常是 "Microsoft Excel")。

示例输出:"Microsoft Excel"

xw.fullname:返回 Excel 应用程序的完整名称(包含版本信息,如 "Microsoft Excel 365")。

示例输出:"Microsoft Excel 365"

 

7.xw.app()的不同用法

.app是指Excel应用程序实例的接口。通过xw.App()来启动Excel实例,或者使用现有的实例。

.app 用于控制 Excel 应用程序级别的操作(如可见性、屏幕更新、计算模式等)。

1.启动/关闭 Excel 实例

1.启动新实例

默认可见。

2.连接已打开的 Excel 实例

3.从打开的工作簿中获取app对象 

2.控制 Excel 的行为

3.打开/操作/保存并关闭工作簿

1.打开工作簿

2.操作工作簿

1.列出各实例中打开的工作簿名称

通过列表推导式。

 2.写入值

3.保存并关闭工作簿

4.获取 app 的键

App 对象代表一个 Excel 应用程序实例,可以获取其唯一标识符(即“键”)。

1.app.pid

返回 Excel 进程的唯一数字标识符(Process ID),由操作系统分配。

 

2.app.hwnd 

返回窗口的唯一标识符(仅 Windows 有效)。

补充:xw.apps.keys()

app.pid 和 app.hwnd 是App对象的属性。

xw.apps.keys()会返回所有正在运行的Excel实例的进程ID列表。

xw.apps是一个类似字典的对象,其中每个键对应一个Excel实例的标识符,而值则是App对象本身。所以xw.apps.keys()应该返回所有当前运行的Excel实例的键(它们的标识符)。 

5.退出 Excel 实例

6..caller() 

如果你通过 Excel 中的 VBA 宏、按钮或其他方式运行 Python 代码,.caller() 会返回调用代码时正在运行的 Excel 应用程序实例。

返回一个 xlwings 的 App 对象,使你可以在 Python 中直接操作触发代码的 Excel 应用程序。

8.xw.save()和 xw.close()


三 xlwings 的高级用法

1.批量操作工作表

2.创建 Excel 图表

charts 集合的 add 方法。

向 Excel 工作表插入一个新的图表。返回一个 Chart 对象,代表新添加的图表,可以通过该对象进一步配置图表(如设置类型、数据源等)。

top=sheet1["A19"].top:图表的顶部位置与单元格 A19 的顶部对齐。

left=sheet1["A19"].left:图表的左侧位置与单元格 A19 的左侧对齐。

图表会被放置在单元格 A19 的位置,覆盖该单元格。

chart.chart_type = "column_clustered":

将图表的类型设置为簇状柱形图(一种常见的柱状图类型)。

chart.set_source_data(sheet1["A15"].expand()):设置图表数据源

sheet1["A15"].expand()

从单元格 A15 开始,自动扩展选择连续的、非空的数据区域。

set_source_data

将上述扩展后的数据区域设置为图表的数据源,图表会根据这些数据生成对应的柱状图。

补充:其他例子

3.结合 Matplotlib

将 Matplotlib 图像放入 Excel 中。

在处理图片时,一定要确保安装了 Pillow,它是 Python 中常用的图片处理库。Pillow 能够保证图片在 Excel 中有正确的尺寸和比例。Anaconda 中包含了 Pillow。

当使用 pandas 的默认绘图后端时,创建的是一张 Matplotlib 的图像。

要将这样的图 像放进 Excel 中,首先要获取它的 figure 对象,然后将其作为参数传递给pictures.add, pictures.add 会将 Matplotlib 图像转换为图片然后发送至 Excel。pictures.add 方法是 xlwings 库中的一个功能,用于将图片添加到 Excel 工作表中。

pictures.add :将图片(如生成的图表)插入到 Excel 工作表中。返回一个 Picture 对象,代表插入的图片,可以通过该对象进一步配置图片(如调整位置、大小等)。

除了接受 Matplotlib 图像, pictures.add 也可以接受磁盘上的图片路径。

image:要插入的图片对象(如 matplotlib 的 Figure 对象)。

name(可选):图片的名称(字符串)。

update(可选):如果为 True,更新现有同名图片;否则添加新图片(默认 False)。

left(可选):图片左侧距离工作表左侧的位置(单位:点)。

top(可选):图片顶部距离工作表顶部的位置(单位:点)。

width(可选):图片的宽度(单位:点)。

height(可选):图片的高度(单位:点)。

 

代码举例:

%matplotlib inline:这是一个魔术命令,用于在 Jupyter Notebook 中直接显示 matplotlib 生成的图表。图表会内嵌在 Notebook 的单元格下方,而不是弹出一个独立的窗口。

plt.style.use("seaborn"):设置 matplotlib 的图表风格为 "seaborn"。seaborn 是一种现代、美观的统计图表风格,由同名库 seaborn 提供。使用此风格后,图表的网格、颜色、字体等视觉元素会自动调整为 seaborn 的默认样式。

ax = df.T.plot.bar():生成一个柱状图,并返回 Axes 对象。

df.T:对 DataFrame df 进行转置(行和列交换)。转置后,原来的行索引(Last Year 和 This Year)会变成列名,原来的列名(North 和 South)会变成行索引。转置是为了调整图表的方向,使柱状图的分组更直观。

.plot.bar():调用 pandas 的绘图方法生成柱状图。

返回的 ax 是一个 Axes 对象,代表图表的坐标轴和绘图区域。

补充:Figure 对象和 Axes 对象

在 matplotlib 中 Figure 对象代表整个图表(包括所有子图、标题、图例等元素)。Axes 对象代表图表中的一个子图或坐标轴区域。

一个 Figure 对象可以包含多个 Axes 对象(例如,通过 plt.subplots() 创建多个子图)。

fig = ax.get_figure():从 Axes 对象中获取关联的 Figure 对象。

.get_figure() :从 Axes 对象中获取其所属的 Figure 对象。

保存图表:通过 Figure 对象可以保存整个图表为文件(如 fig.savefig("chart.png"))。

调整图表布局:通过 Figure 对象可以调整图表的全局布局(如 fig.tight_layout())。

获取图表属性:通过 Figure 对象可以访问图表的尺寸、分辨率等属性。

补充:.get_figure() 方法是 matplotlib 中用于从 Axes 对象获取其所属 Figure 对象的关键方法。通过 Figure 对象,用户可以执行保存图表、调整布局等高级操作。

补充:想使用新的图像来更新图片

只需调用 update 方法并传递另一个 figure 对象即可。虽然这样做会替换 Excel 中的图片,但会保留位置、尺寸、名称等属性。

(df + 1):对 DataFrame df 中的每个元素加 1。

转置后:

.plot.bar():调用 pandas 的绘图方法生成柱状图返回的 ax 是一个 Axes 对象,代表图表的坐标轴和绘图区域。

plot = plot.update(ax.get_figure()):用新的 Figure 对象更新已有的图表对象。

4.已定义名称集合

1.什么是已定义名称

在 Excel 中,我们通过为区域、公式和常量赋予名称来创建已定义名称。为一个区域命名是常见情况,这种区域被称作具名区域。利用具名区域,你可以在公式和代码中使用描述性名称而不是抽象地址(A1:B2)来引用一个 Excel 区域。

补充:

具名区域:给某个单元格或单元格区域赋予一个名称(如 SalesData),方便在公式或图表中引用。

全局作用域:名称在整个工作簿中唯一,任何工作表都能引用。

工作表作用域:名称仅在当前工作表中唯一,复制到其他工作表时会自动重命名。

利用具名区域读写值可以在不调整 Python 代码的情况下重新组织工作簿。比如,即使插入新行导致了单元格的移动,但对应的名称仍然引用的是原来的单元格。自定义名称可以在全局工作簿作用域或局部工作表作用域中设置。

工作表作用域的优势是在复制工作表时不用担心重复的具名区域发生冲突。

什么是工作表作用域的优势是在复制工作表时不用担心重复的具名区域发生冲突?

假设你有一个工作表 Sheet1,其中定义了一个全局作用域的具名区域 SalesData。当你复制 Sheet1 到 Sheet2 时:Sheet2 中也会出现一个名为 SalesData 的具名区域。如果此时你尝试在公式或图表中引用 SalesData,软件会不知道引用的是 Sheet1 还是 Sheet2 中的 SalesData,导致冲突。

在 Excel 中,你可以在“公式 > 定义名称”菜单项中添加自定义名称。也可以选择一个区域,然后将想要的名称写到名称框(公式栏左边的文本框)中,你可以在这里看到默认的单元格地址。

2.使用 xlwings 创建自定义名称的方法

默认作用域是工作簿作用域。

sheet1["A1:B2"].name = "matrix1"

工作表作用域需要在工作表名称前加上一个感叹号。

sheet1["B10:E11"].name = "Sheet1!matrix2"

3.通过名称访问区域

1.用 sheet 方法

sheet1["matrix1"]

返回当前工作表(sheet1)中定义的工作表作用域的具名区域。

原因:工作表对象只能“看到”其内部定义的作用域为当前工作表的具名区域。

2.用 book 方法

book.names

返回整个工作簿(book)中定义的所有作用域的具名区域。

原因:工作簿对象可以“看到”全局作用域和工作表作用域的具名区域。

4.名称有多种方法和属性

1.获取对应的range对象

book.names["matrix1"].refers_to_range

获取工作簿中名为 matrix1 的具名区域所引用的具体单元格范围。

book 是工作簿对象(如 Excel 文件)。book.names 是工作簿中所有具名区域的集合,包含工作簿作用域和工作表作用域的具名区域。通过名称 matrix1 从 book.names 集合中获取特定的具名区域对象。

.refers_to_range:是具名区域对象的一个属性,返回该具名区域所引用的具体单元格范围(Range 对象)。例如,如果 matrix1 引用的是 Sheet1!A1:B2,那么 .refers_to_range 会返回这个范围。

2.为常量或公式取名

使用add方法。

book.names.add("EURUSD", "=1.1151")

"EURUSD":是新具名区域的名称,遵循命名规则(如不能以数字开头,不能包含空格等)。

=1.1151":如果直接赋值(如 =1.1151),表示该具名区域的值是 1.1151。如果引用单元格(如 =Sheet1!A1),表示该具名区域的值是 Sheet1!A1 单元格的值。

5.通过 Python 来运行 VBA 宏

如果你手上有一些包含大量 VBA 代码的旧式 Excel 项目,那么要将所有东西都迁移到 Python 并非易事。在这种情况下,可以通过 Python 来运行 VBA 宏。

xlwings 通过 macro() 方法将 VBA 代码桥接到 Python,使其像原生函数一样调用。
xl 文件夹中的 vba.xlsm 文件。文件的 Module1 中有如下代码:

步骤1:连接 VBA 工作簿

通过 xw.Book() 加载包含 VBA 代码的 vba.xlsm 文件。返回一个 Book 对象 vba_book,用于操作该工作簿。

步骤2:绑定 VBA 函数

vba_book.macro( ) 将 VBA 函数 MySum 绑定到 Python 变量 mysum。此时 mysum 像一个 Python 函数,可直接调用。

调用:

传递参数 5 和 4 给 VBA 函数 MySum ,VBA 执行 x + y 计算,返回结果 9.0

步骤3:绑定 VBA 子程序

同理,将 VBA 子程序 ShowMsgBox 绑定到 show_msgbox。子程序无返回值,但会执行操作(如弹窗)。

调用:

    传递字符串参数 "Hello xlwings!"。VBA 执行 MsgBox 弹出消息框,需手动关闭后才能继续。

    步骤4:关闭工作簿

    关闭book对象(一定要先关闭对话框)。若子程序弹出对话框未关闭,直接关闭工作簿会报错。 

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

    如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

    相关文章

    STL之空间配置器

    1. 什么是空间配置器 空间配置器,顾名思义就是为各个容器高效的管理空间(空间的申请与回收)的,在默默地工作。虽然在常规使用STL时,可能用不到它,但站在学习研究的角度,学习它的实现原理对我们有很大的帮助。 2. 为什…

    Axure项目实战:智慧城市APP(三)教育查询(显示与隐藏交互)

    亲爱的小伙伴,在您浏览之前,烦请关注一下,在此深表感谢! 课程主题:教育查询 主要内容:教育公告信息,小升初、初升高、高考成绩查询;教育公告信息为传统的信息页面,小升…

    最大字段和问题 C++(穷举、分治法、动态规划)

    问题描述 给定由n个整数(包含负整数)组成的序列a1,a2,…,an,求该序列子段和的最大值。规定当所有整数均为负值时定义其最大子段和为0 穷举法 最简单的方法就是穷举法,用一个变量指示求和的开始位置,一个变量指示结束…

    【数据转换】- Halcon<->Mat

    背景介绍 最近在写C#联合Haclon调用C的.dll文件进行联合编程。大致需求就是C#设计界面,然后调用Haclon的图像处理库,C把目标检测的模型进行TensorRT部署生成动态链接库,之后界面操作加载模型、对图像进行检测等功能。 设计界面如下&#xf…

    MFC中如何判断一个窗口当前状态是显示还是隐藏

    文章目录 一、核心方法:使用 CWnd::IsWindowVisible函数原型示例代码 二、注意事项1. 父窗口的影响2. 窗口最小化/最大化状态3. 窗口尚未创建 三、扩展:通过窗口样式直接判断四、完整示例代码五、总结 在MFC中,判断窗口当前是显示还是隐藏状态…

    Java 大视界 -- 基于 Java 的大数据分布式系统的监控与运维实践(155)

    💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

    消息队列性能比拼: Kafka vs RabbitMQ

    本内容是对知名性能评测博主 Anton Putra Kafka vs RabbitMQ Performance 内容的翻译与整理, 有适当删减, 相关数据和结论以原作结论为准。 简介 在本视频中,我们将首先比较 Apache Kafka 和传统的 RabbitMQ。然后,在第二轮测试中,会将 Kaf…

    [ComfyUI] SDXL Prompt Styler 自定义节点的作用解析

    1. SDXL Prompt Styler 的位置与基本功能 在 ComfyUI 的 “新建节点” → “实用工具” 下,可以找到 Style 节点(SDXL Prompt Styler)。该节点的主要作用是对输入的描述进行结构化处理,并在转换为 Stable Diffusion XL (SDXL) 提示词时,自动补充风格相关的内容,使提示词…

    【JavaScript】金丹期功法

    目录 数组声明数组数组的基本使用遍历数组案例:求数组中的最值数组操作查询数据修改数据新增数据案例:数组筛选删除数据 案例:渲染柱形图 数组 数组(Array)是一种可以按顺序保存数据的数据类型 场景:如果…

    学习本地部署DeepSeek的过程(基于LM Studio)

    除了使用Ollama部署DeepSeek,还可以使用LM Studio部署DeepSeek,后者是一款允许用户在本地计算机上运行大型语言模型(LLMs)的桌面应用程序,旨在简化本地模型的使用,无需云端连接或复杂配置即可体验 AI 功能。…

    AOA与TOA混合定位,MATLAB例程,自适应基站数量,三维空间下的运动轨迹,滤波使用EKF

    本代码实现了一个基于 到达角(AOA) 和 到达时间(TOA) 的混合定位算法,结合 扩展卡尔曼滤波(EKF) 对三维运动目标的轨迹进行滤波优化。代码通过模拟动态目标与基站网络,展示了从信号测量、定位解算到轨迹滤波的全流程,适用于城市峡谷、室内等复杂环境下的定位研究。 文…

    C++:函数(通识版)

    一、函数的基础 1.什么是函数?(独立的功能单位) 函数是C中封装代码逻辑的基本单元,用于执行特定任务。 作用:代码复用、模块化、提高可读性。 2、函数的基本结构 返回类型 函数名(参数列表) {// 函数体return 返回值…

    STL之map和set

    1. 关联式容器 vector、list、deque、 forward_list(C11)等,这些容器统称为序列式容器,因为其底层为线性序列的数据结构,里面存储的是元素本身。 关联式容器也是用来存储数据的,与序列式容器不同的是,其里面存储的是结…

    虚拟机(一):Java 篇

    虚拟机(一):Java 篇 虚拟机(二):Android 篇 架构 运行时数据区: 栈: 堆: 堆:通过new创建的对象都在堆中分配。OutOfMemoryError TLAB(Thread Local All…

    无线安灯按钮盒汽车零部件工厂的故障告警与人员调度专家

    在汽车零部件制造领域,生产线故障与物料短缺等问题往往引发连锁反应,导致停机损失与成本激增。传统人工巡检与纸质工单模式已难以满足高效生产需求,而无线安灯按钮盒的智能化应用,正成为破解这一难题的关键利器。 一、精准告警&am…

    二叉树相关算法实现:判断子树与单值二叉树

    目录 一、判断一棵树是否为另一棵树的子树 (一)核心思路 (二)代码实现 (三)注意要点 二、判断一棵树是否为单值二叉树 (一)核心思路 (二)代码实现…

    数据结构初阶-二叉树链式

    目录 1.概念与结构 2.二叉数链式的实现 2.1遍历规则 2.2申请内存空间 2.3手动构建一棵二叉树 2.4二叉树结点的个数 2.5二叉树叶子结点的个数 2.6二叉树第K层结点个数 2.7二叉树的高度 2.8二叉树中查找值为x的结点 2.9二叉树的销毁 3.层序遍历 3.1概念 3.2层序遍历…

    SpringMVC拦截器

    SpringMVC拦截器 什么是拦截器拦截器和过滤器的区别SpringMVC 拦截器的工作原理拦截器的配置拦截器的配置主要有两种方式XML 配置方式Java配置方式 创建一个拦截器拦截器的应用场景拦截器的执行顺序 什么是拦截器 SpringMVC 的拦截器(Interceptor)是指在…

    cocos creator 笔记-路边花草

    版本:3.8.5 实现目标:给3d道路生成路边景观花草 在场景下创建一个节点,我这里种植两种花草模型,兰花和菊花,所以分别在节点下另创建两个节点,为了静态合批。 1.将花草模型分别拖入场景中,制作…

    YoloV8训练和平精英人物检测模型

    概述 和平精英人物检测,可以识别游戏中所有人物角色,并通过绘制框将人物选中,训练的模型仅仅具有识别功能,可以识别游戏中的视频、图片等文件,搭配Autox.js可以推理,实现实时绘制,但是对手机性…