文章背景:在采用VBA抓取数据时,有时需要判断指定数值是否在一维数组中已存在;如果存在,则希望能够获取该数值在数组内的位置。...在实践过程中发现,VBA的filter函数无法完全匹配指定数值;而借助Excel的match函数,可以实现完全匹配。接下来分别对Filter函数和Match函数进行介绍。...Filter ( sourcearray , match , [ include , [ compare ]]) sourcearray 必要项目。要搜寻的字串的一维阵列。...应用示例: 判断某字符串是否在一维数组内存在。 由上图可以看出,采用Filter函数匹配到的是包含A-1的所有元素。而在实际案例中,可能希望只获得完全匹配的元素。...WorksheetFunction.Match 方法 傳回項目在陣列中的相對位置,其符合指定順序中的指定值。
标签:VBA,列表框,用户界面 有时候,可能你想自动选择列表框中的第一项或者最后一项。例如,当选择列表框所在的工作表时,列表框自动选择第一项,或者选择最后一项。这都可以使用简单的VBA代码轻易实现。...,第二个过程在单击命令按钮后选择列表框中的最后一项。...而Activate事件,当该工作表成为当前工作表时,自动执行相应的过程,从而选择列表框中的第一项。 这些过程是如何工作的呢?它们是在计算列表框中所有列表项数的前提下工作的。...在第一个过程中,使用一个简单的循环从列表框的底部开始,一直到顶部。...列表框中共有7项,Step -1告诉循环在每次循环迭代中从i减少1。 对于第二个过程,在循环内调用相反的过程。从顶部开始,向下直到底部,然后停止。
标签:VBA,用户窗体 这是一个很好的示例,充分展示了VBA和用户窗体控件编程技术。 示例中有一个数据工作表Sheet1,包含有一个列表,每一行的单元格中都有很多用逗号分隔的数据,如下图1所示。...3.在用户窗体中: (1)左侧列表框列出了工作表Sheet2中的所有唯一项。 (2)在搜索框中输入内容时,会随着输入自动缩减左侧列表框中的内容。...(5)选择右侧列表框中的项目,单击“移除”按钮,该项目会自动移至左侧列表框。 (6)单击“筛选重置”按钮会重置列表框数据和工作表筛选。...(8)“选择类型”中,选中“选择多项”,则可以在列表框中选择多个项目;选中“选项一项或者按下Shift或Ctrl键选择多项”,则只能选择列表框中的一个项目,要选择多个项目,要按下Shift键或者Ctrl...…… 有兴趣的朋友可以在完美Excel微信公众号中发送消息: 筛选数据示例 获取示例工作簿下载链接。 或者,直接到知识星球App完美Excel社群中下载该示例工作簿。
在项目编译成 dll 之前,如何分析项目的所有依赖呢?可以在在项目的 Target 中去收集项目的依赖。...本文将说明如何在 Target 中收集项目依赖的所有 dll 的文件路径。...注意,我在 BeforeTargets 上增加了一个 ResolveAssemblyReference。...Reference 的输出 可以看到,Reference 的输出几乎就是 Reference 中写的字符串本身。...,项目编译好的 dll 的路径也在。
标签:VBA 使用功能区“开发工具”选项卡,我们可以在工作表中插入控件,例如,可以插入列表框控件,如下图1所示。...图1 插入列表框控件后,单击右键,选择“设置控件格式”命令,可以选取“选定类型”中的“复选”,从而允许我们同时选取列表框中的多个项目,如下图2所示。...图2 然而,Excel并没有提供给我们指示在工作表中列出了多个选项,所链接的单元格只是显示0,如下图3所示。...图3 下面是在mrexcel.com中看到的一段代码,通过在工作表中项目列表右侧的列中显示用户的选择状态来解决此问题,如下图4所示。...图4 宏代码如下: '获取多选列表框中的选定项,并将其列在工作表中原始项列表的右侧列 Sub getSelections() Dim V As Variant Dim V2 As Variant
QListWidget 是 Qt 中的一个列表框组件,用于显示一列项目,并允许用户进行选择。每个项目可以包含一个图标和文本,可以使用 QListWidgetItem 类来表示。...以下是概述: 获取所有项数量: 使用 ui->listWidget->count() 获取列表框中的项的数量。 循环设置状态: 使用 for 循环遍历每个项,获取当前项的句柄。...以下是概述: 获取总数: 使用 ui->listWidget->count() 获取列表框中的项的总数。 循环设置选中状态: 使用 for 循环遍历每个项,获取每个项的指针。...以下是概述: 获取总数: 使用 ui->listWidget->count() 获取列表框中的项的总数。 循环设置非选中状态: 使用 for 循环遍历每个项,获取每个项的指针。...以下是概述: 获取总数: 使用 ui->listWidget->count() 获取列表框中的项的总数。 循环设置反选状态: 使用 for 循环遍历每个项,获取每个项的指针。
前言我们在日常使用各种桌面软件时,当我们想要搜索一个内容时,都会出现一个列表框,供我们选择,如下图:图片Tkinter提供了列表框(Listbox)控件来实现类似的功能。...Listbox控件列表框,即 Listbox。在使用 Tkinter 进行 GUI 编程的过程中,如果需要用户自己进行选择时就可以使用列表框控件。...列表框中的选项可以是多个条目,也可以是单个唯一条目,但常用于多个条目。....指向一个 StringVar 类型的变量,该变量存放 Listbox 中所有的项目 2.在 StringVar 类型的变量中,用空格分隔每个项目,例如 var.set("c c++ java python...bt.pack(side = BOTTOM)# 显示窗口win.mainloop()程序运行结果,如下所示:图片StringVar() 添加列表选项通过 StringVar() 方法动态地获取列表框中的选项
标签:VBA 我们经常会在VBA代码中看到Application.Caller,它到底起什么作用,往往让人感到模糊。下面,我们就来详细讲讲,对其有更深入的理解。 有下列3种常见情形。...例如,如果从单元格/单元格区域调用UDF(用户定义函数),并且希望获取从中调用它的单元格/单元格区域的地址,那么可以使用以下代码实现。本例返回Range,也可以将它设置为某个对象。...图1 情形2:如果调用者是某控件(例如,下拉菜单、列表框、命令按钮等)或形状,则Application.Caller返回代表调用者名称的字符串。...图2 情形3:如果调用者是VBA过程或函数,则Application.Caller返回错误。 例如,如果在某个过程或函数中调用上面的函数testControl,则它将返回错误。...图3 注意,Application.Caller在立即窗口中不工作。 相关文章:一段代码,显式确定工作表列表框选项状态>>>
标签:Word VBA 有多种方法可以使我们在创建、打开或关闭Word文档时自动运行宏。...此时,在右侧代码窗口顶部,会看到两个列表框。单击左侧下拉列表,将其从“(通用)”更改为“Document”,VBA将自动创建一个名为Document_New()的过程。...不过,存储在加载项(存储在Word启动目录中的.dotm文件)中的AutoNew、AutoOpen和AutoClose宏将无法全局运行。...但是,在Normal.dotm中存储宏存在一些问题,因此如果想避免这种情况,最好使用应用程序事件。存储在全局加载项中的应用程序事件确实具有全局行为。一些应用程序事件与文档相关。...可以使用Application对象的DocumentOpen、NewDocument和DocumentBeforeClose事件,将它们存储在加载项中的工作方式与在Normal.dotm中存储自动宏类似
列表框会拥有一个垂直滚动条 ,在列表框不能够显示所有项时显示。...添加文件名列表 LB_FINDSTRING 返回列表框中的一个字符的索引 LB_FINDSTRINGEXACT 在列表框查找第一个与特定字符匹配的字符并返回它的索引 LB_GETANCHORINDEX...获取锚点的索引,锚点就是在多选模式下选中的第一项 LB_GETCARETINDEX 在多选模式下返回具有焦点条目的索引 LB_GETCOUNT 获取列表框中子项的总数 LB_GETCURSEL 获取被选中的子项的索引...,只在单选模式下有效 LB_GETHORIZONTALEXTENT 获取水平滚动条的宽度 LB_GETITEMDATA 获取与指定列表项相关的程序的自定义值(长度为32位) LB_GETITEMHEIGHT...LB_GETTEXT 获取指定项的字符串 LB_GETTEXTLEN 获得指定项字符串的长度 LB_GETTOPINDEX 获取列表框中显示的第一列的索引,当使用滚动条使显示内容发生变化时,这个索引也会发生改变
本文主要讲解操控工作表中一些界面元素的VBA代码。 名称框 名称框中的名字是为单元格区域定义的名字,可以由用户定义名称,或者由Excel自动创建,例如Print_Area和表1。...示例代码: '设置距离窗格或窗口顶部的特定行 '设置距离顶部行5行 ActiveWindow.ScrollRow= 5 '设置距离窗格或窗口最左侧的特定列 '设置距离最左侧列8列 ActiveWindow.ScrollColumn...如果要指定滚动的窗格,可以使用类似下面的语句,例如,在第2个窗格中滚动到距离最左侧列10列: ActiveWindow.Panes(2).ScrollColumn= 10 如果拆分的窗格被冻结,那么ScrollRow...设置滚动区域 示例代码: '设置工作表的滚动区域 '限制在单元格区域C5:J30 ActiveSheet.ScrollArea= "C5:J30" 但是,用户仍然能够通过在名称框中输入单元格地址来访问不在滚动区域中的任何单元格...注意,代表颜色值的常量可以在VBA帮助系统中查找。
创建 NDK 项目 II . NDK 项目 相关配置 III . NDK 中获取 Android 版本号 IV . 使用 __system_property_get 可获取的参数 I ...., 然后创建 CMakeList.txt 编译脚本 , 最后在 build.gradle 中配置该编译脚本 , 这里不再详细描述 ; 在菜单栏中选择 File -> New -> New Project..., 在弹出的对话框中选择 Native C++ 项目 ; 2....NDK 中获取 Android 版本号 ---- 1....参数字符串来源 : 上述的参数字符串都定义在 Android 系统中的 build.prop 配置文件中 ; 4.
标签:VBA,用户窗体 下面分享的是两个非常好的作品,在Excel中使用VBA实现在组合框或列表框中进行自动筛选,就像我们在用百度搜索时那样,随着用户的输入,会逐渐减少相匹配的下拉列表项,以方便用户快速进行选择...如下图1所示,随着用户在组合框中的输入,下拉列表中会逐渐缩小匹配的项,当只有唯一项匹配时,就直接输入该项。...图1 另一个示例工作簿添加了使用列表框/文本框实现与上面相同的功能,如下图2所示,并扩展能使用特殊字符和通配符,对筛选条件也提供了多个选项,包括以输入文本开头、包含输入文本、不包含输入文本、以输入文本结尾...图2 有兴趣的朋友可以到ozgrid.com论坛中下载这两个示例工作簿,也可以在完美Excel公众号发送消息: 自动筛选搜索 获取这两个示例工作簿的下载链接。...正如我经常所说的,学习优秀的示例是我们提高水平的一种快速方法,遇到优秀的示例,我们可以将其收藏起来,平时多研究其实现方式、代码组织及其代码;此外,其中一些代码也可以直接在我们的开发实践中利用,大大提高开发效率
列表类控件 10、ListBox 控件 ListBox 控件又称列表框,它在工具箱中的图标为,它显示一个项目列表供用户选择。在列表框中,用户一次可以选择一项,也可以选择多项。...完成向列表框中添加项的任务后,再调用 EndUpdate 方法使 ListBox 控件重新绘制。当向列表框中添加大量的列表项时,使用这种方法添加项可以防止在绘制 ListBox 时的闪烁现象。...11、ComboBox 控件 ComboBox 控件又称组合框,在工具箱中的图标为。默认情况下,组合框分两个部分显示:顶部是一个允许输入文本的文本框,下面的列表框则显示列表项。...HScrollBar 在工具箱中的图标是,VScrollBar控件在工具箱中的图标是。这两 个控件主要用于在应用程序或控件中水平或垂直滚动,以方便在较长的列表中或大量信息中 转移。...C#项目刚建立时只有一个名为Form1的窗体,要建立多窗体应用程序应首先为项目添加窗体,添加窗体的方法如下。
excelperfect 引言:这是在知识星球App的完美Excel社群中发表的Excel VBA编程系列文章中的一篇,使用一个示例来讲解用户窗体的基础应用。...提供一个用于选择state的列表框控件。 显示一个“下一步”命令按钮,该按钮将当前数据保存在工作表中,并再次显示该窗体以输入更多数据。...如你在第20课中所学习的,此事件接收一个参数,该参数标识所按下的键。如果该键可以接受,则将其传递;否则取消。 在VBA联机帮助中的KeyCode值列表中,你可以看到键0到9的代码值为48到57。...2.使用CurrentRegion属性获取包含标题行和所有现有数据的区域。 3.使用Offset方法以原始区域中的行数获得区域偏移。此新区域比原始区域低一行,并且在第一个空行中包含六个单元格。...在开始编程之前计划项目总是一个好主意。 数据验证是任何数据输入程序的重要组成部分。 可以在输入数据之后或输入数据时执行数据验证。 当你的代码将在程序的多个位置中使用时,将其放在单独的过程中。
标签:VBA,自定义函数 我想要列出文件夹及其子文件夹中名为test的Excel文件,如何使用VBA程序实现?...'参数: strPath = 要搜索的路径. ' strFileSpec = "*.*" 除非另有指定. ' bIncludeSubfolders: 如果为True,同时从strPath的子文件夹中返回结果.... ' lst: 如果传递到列表框, 则在其中添加项....如果不, 则将文件在立即窗口列出. ' 列表框必须具有其Row Source Type属性设置为Value列表. '方法:FilDir()添加项到集合, 对子文件夹递归调用自身....varItem As Variant Call FillDir(colDirList, strPath, strFileSpec, bIncludeSubfolders) '如果传入,将其添加到列表框中
手风琴一般被用来减少页面滚动,当在单个页面中呈现很多内容模块时。 通过以下术语来理解手风琴: 手风琴标题: 呈现内容模块的标签或缩略图,同时也用来展开内容,在某些实现中,也用来隐藏内容模块。...允许选择一个选项的列表框是一个单选列表框;允许选择多个选项的列表框是一个多选列表框。 当屏幕阅读器呈现一个列表框,可能会渲染出其名称、状态和每个选项在列表中的位置。...如果可用选项的集合没有完整地显示在DOM中,而是根据用户滚动动态加载,它们的 aria-setsize 和 aria-posinset 适当设定。...例如,在使用树视图显示文件夹和文件的文件系统导航器中,代表文件夹的项目能够被展开文件夹中的内容,这些内容可能是文件、文件夹,或两者都有。 理解的树视图的一些术语包括: 节点 在树结构中的项目。...但是,在多选择树(multi-select trees)中,允许用户一次性选择多个项目,其选择状态与焦点无关。
●●●●● 相信大家都会觉得上图中底部的图要比顶部的数据表看起来省时省力多了,对于增长趋势一览无余、一目了然。 其实想要在数据表格中凸显增长趋势,在excel中有很多种实现方式。...然后调出单元格格式选项卡(开始——数字——下拉菜单中的自定义) ? 在自定义输入框中黏贴进去这个语句就可以实现以上效果。...刘(万祥)老师用VBA把以上的语法写成了宏代码,而且介绍了怎么把宏代码做成快捷菜单内置到菜单栏中。以后只要一打开excel,选定数据区域之后一键就可以生成以上图表。...在你的excel开发工具中点开VBA编辑器 ? 然后在当前工作薄的工作表中插入一个模块。 在新插入的模块中黏贴入以上代码。 ?...在左侧列表框的常用命令中选择宏。 此时你会发现现有宏列表中有一个叫arrow_percent的选项,选择添加,并命名。 ?
当然列表项可以只包含图 标也可以只包含标签 Tree Control控件 树形控件在Windows系统中是很常见的,例如资源 管理器左侧的窗口中就有用来显示目录的树形视图。...树形控件在插入新的树节点时会稍麻烦些,回顾之 前的列表框,插入新列表项时调用AddString成员函数 就可以了,而对于树形控件则需要指定新节点与已有节 点的关系。...图片控件静态和动态加载位图图片 【滚动条控件简介】 滚动条大家也很熟悉了,Windows窗口中很多都有滚动条。 前面讲的列表框和组合框设置了相应属性后,如果列表项显 示不下也会出现滚动条。...像列表框和组合框设置了WS_HSCROLL或 WS_VSCROLL风格以后出现的滚动条,不是一个独立的窗 口,而是这些窗口的一部分,这就是标准滚动条。...用于绘制的设备上下文 SendMessage(WM_ICONERASEBKGND, reinterpret_cast(dc.GetSafeHdc()), 0); // 使图标在工作区矩形中居中
标签:VBA,用户窗体,列表框 有时候,我们想从数据表中搜索指定的内容,但匹配项往往不只一项,而我们想要将匹配项全部显示出来,如下图1所示。...图1 在Excel中,有很多方法可以实现,这里使用用户窗体和VBA代码来完成。 示例数据如下图2所示。 图2 单击“查找”按钮,弹出我们所设计的用户窗体如下图3所示。...SearchTerm = Department.Value SearchColumn = "部门" End If Results.Clear ' 仅在相关表格列中搜索...Set FirstCell =Range("A" & RecordRange.Row) ' 添加匹配记录到列表框...If RecordRange Is Nothing Then Exit Sub End If ' 在找到唯一匹配项时继续查找
领取专属 10元无门槛券
手把手带您无忧上云