首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用VBA在excel中匹配2列中多次出现的值

在Excel中使用VBA匹配两列中多次出现的值,可以通过以下步骤实现:

  1. 打开Excel,并按下Alt + F11打开VBA编辑器。
  2. 在VBA编辑器中,插入一个新的模块。右键点击项目资源管理器中的工作簿,选择"插入",然后选择"模块"。
  3. 在新的模块中,编写以下VBA代码:
代码语言:vba
复制
Sub MatchDuplicates()
    Dim ws As Worksheet
    Dim rng1 As Range, rng2 As Range
    Dim cell As Range
    Dim dict As Object
    Dim result As String
    
    ' 设置工作表和要匹配的范围
    Set ws = ThisWorkbook.Worksheets("Sheet1") ' 替换为实际的工作表名称
    Set rng1 = ws.Range("A1:A10") ' 替换为实际的第一列范围
    Set rng2 = ws.Range("B1:B10") ' 替换为实际的第二列范围
    
    ' 创建字典对象
    Set dict = CreateObject("Scripting.Dictionary")
    
    ' 遍历第一列,将值添加到字典中
    For Each cell In rng1
        If Not dict.exists(cell.Value) Then
            dict.Add cell.Value, 1
        End If
    Next cell
    
    ' 遍历第二列,检查是否存在于字典中
    For Each cell In rng2
        If dict.exists(cell.Value) Then
            result = result & cell.Value & ", "
        End If
    Next cell
    
    ' 输出匹配结果
    If Len(result) > 0 Then
        MsgBox "匹配的值为:" & Left(result, Len(result) - 2)
    Else
        MsgBox "没有匹配的值。"
    End If
End Sub
  1. 替换代码中的工作表名称和要匹配的范围,确保与实际情况相符。
  2. 按下F5运行代码,将会弹出一个消息框,显示匹配的值。

这段VBA代码通过使用字典对象来实现匹配功能。首先,它遍历第一列并将值添加到字典中。然后,它遍历第二列并检查每个值是否存在于字典中。如果存在,则将其添加到结果字符串中。最后,根据结果字符串的长度,弹出相应的消息框显示匹配的值或者没有匹配的值。

这是一个基本的VBA代码示例,可以根据实际需求进行修改和扩展。关于VBA的更多信息和学习资源,可以参考腾讯云的Excel VBA开发文档:Excel VBA开发

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Excel公式技巧17: 使用VLOOKUP函数多个工作表查找相匹配(2)

我们给出了基于多个工作表给定列匹配单个条件来返回解决方案。本文使用与之相同示例,但是将匹配多个条件,并提供两个解决方案:一个是使用辅助列,另一个不使用辅助列。 下面是3个示例工作表: ?...图3:工作表Sheet3 示例要求从这3个工作表从左至右查找,返回Colour列为“Red”且“Year”列为“2012”对应Amount列,如下图4所示第7行和第11行。 ?...16:使用VLOOKUP函数多个工作表查找相匹配(1)》。...解决方案2:不使用辅助列 首先定义两个名称。注意,定义名称时,将活动单元格放置工作表Master第11行。...D1:D10 传递到INDEX函数作为其参数array: =INDEX(Sheet3!

13.5K10

Excel公式技巧16: 使用VLOOKUP函数多个工作表查找相匹配(1)

某个工作表单元格区域中查找时,我们通常都会使用VLOOKUP函数。但是,如果在多个工作表查找并返回第一个相匹配时,可以使用VLOOKUP函数吗?本文将讲解这个技术。...最简单解决方案是每个相关工作表中使用辅助列,即首先将相关单元格连接并放置辅助列。然而,有时候我们可能不能在工作表中使用辅助列,特别是要求在被查找表左侧插入列时。...图3:工作表Sheet3 示例要求从这3个工作表从左至右查找,返回Colour列为“Red”对应Amount列,如下图4所示。 ?...B1:D10"),3,0) 其中,Sheets是定义名称: 名称:Sheets 引用位置:={"Sheet1","Sheet2","Sheet3"} 公式中使用VLOOKUP函数与平常并没有什么不同...B:B"}),$A3) INDIRECT函数指令Excel将这个文本字符串数组元素转换为单元格引用,然后传递给COUNTIF函数,同时单元格A3作为其条件参数,这样上述公式转换成: {0,1,3

20.6K21

Excel,如何根据求出其坐标

使用excel过程,我们知道,根据一个坐标我们很容易直接找到当前坐标的,但是如果知道一个坐标里,反过来求该点坐标的话,据我所知,excel没有提供现成函数供使用,所以需要自己用VBA编写函数使用...(代码来自互联网) Excel,ALT+F11打开VBA编辑环境,左边“工程”处添加一个模块 把下列代码复制进去,然后关闭编辑器 Public Function iSeek(iRng As Range...c.Address(False, False): Exit For Next If iAdd = "" Then iSeek = "#无" Else iSeek = iAdd End Function 然后即可在excel...表格编辑器中使用函数iSeek了,从以上代码可以看出,iSeek函数带三个参数,其中第一个和第二个参数制定搜索范围,第三个参数指定搜索内容,例如 iSeek(A1:P200,20),即可在A1与...P200围成二维数据表搜索“20“了。

8.6K20

Excel如何匹配格式化为文本数字

标签:Excel公式 Excel,如果数字一个表中被格式化为数字,而在另一个表中被格式化为文本,那么尝试匹配或查找数据时,会发生错误。 例如,下图1所示例子。...图1 单元格B6以文本格式存储数字3,此时当我们试图匹配列B数字3时就会发生错误。 下图2所示是另一个例子。 图2 列A中用户编号是数字,列E是格式为文本用户编号。...现在,我们想查找列E用户编号,并使用相对应列F邮件地址填充列B。 显然,如果只是像常规一样使用INDEX/MATCH查找,则会发生错误,如下图3所示。...图7 这里成功地创建了一个只包含数字新文本字符串,VALUE函数帮助下将该文本字符串转换为数字,然后将数字与列E进行匹配。...图8 这里,我们同样成功地创建了一个只包含数字新文本字符串,然后VALUE函数帮助下将该文本字符串转换为数字,再将我们数字与列E进行匹配

5.2K30

Excel VBA解读(140): 从调用单元格获取先前计算

学习Excel技术,关注微信公众号: excelperfect 如果有一个依赖于一些计算慢资源用户定义函数,可能希望该用户定义函数大多数情况下只返回其占用单元格中最后一次计算得到,并且只偶尔使用计算慢资源...可以设置开关(这里使用称为“RefreshSlow”已定义名称)并在VBA过程刷新用户定义函数,如下所示: Sub RefreshUDFs() Dim lCalcMode As Long...已保存”工作簿,因此下次打开工作簿时,检索到将为“空白/零”。...下面是名为PREVIOUSXLL+函数代码,该函数具有使其成为易失性或非易失性参数。(命令等效函数默认为易失性,但在使用它将前一个传递给VBA用户定义函数时,通常希望它是非易失性)。...小结 有几种方法可以从VBA用户定义函数最后一次计算获取先前,但最好解决方案需要使用C++ XLL。

6.7K20

Excel实战技巧55: 包含重复列表查找指定数据最后出现数据

图1 下面,我们分别使用公式和VBA来解决。...)-1)) 公式先比较单元格D2与单元格区域A2:A10,如果相同返回TRUE,不相同则返回FALSE,得到一个由TRUE和FALSE组成数组,然后与A2:A10所行号组成数组相乘,...得到一个由行号和0组成数组,MAX函数获取这个数组最大,也就是与单元格D2相同数据A2:A10最后一个位置,减去1是因为查找是B2:B10,是从第2行开始,得到要查找...组成数组,由于这个数组找不到2,LOOKUP函数在数组中一直查找,直至最后一个比2小最大,也就是数组最后一个1,返回B2:B10对应,也就是要查找数据列表中最后。...图3 使用VBA自定义函数 VBE输入下面的代码: Function LookupLastItem(LookupValue AsString, _ LookupRange As Range,

10.4K20

正则表达式密码强度匹配使用

二、解决方法   以第三种为例,这个可以分解为如下需求: 存在数字 存在字母 存在半角符号 长度六位及以上 关键是如何同时满足前三个条件,我有限知识里并不知道怎么搞,然后只好求助于万能百度了,最终找了几个小时后发现如下几个关键词...=pattern) :正向预测先行搜索 名字看着高大上,不明所以,看完示例大概明白什么意思,这个表达式匹配从这个表达式起始字符串(我也不知道咋解释),就是假设这样一个表达式abc(?...=[abc])只会对作用于后面的123,这个显然是不匹配后整个就不匹配了,然后关键来了名字里有预测两个字,这两个字表名了这个表达式特性:不占用字符,匹配后如果匹配成功就继续匹配了好像从来不存在这个东西一样...,匹配失败就立即返回失败了。...pattern) :反向预测先行搜索 概念和上面一样,但是效果是相反,abc(?[abc]),对于abc123是匹配成功,对于abca匹配失败,如下所示: reg = /abc(?!

3.9K30

Excel实战技巧67:组合框添加不重复使用ADO技巧)

很多情况下,我们需要使用工作表数据来填充组合框,但往往这些数据中含有许多重复。如何去除重复并得到唯一,这是一个永恒的话题,大家也会用到各式各样方法得到结果。...本文讲解一种技巧,使用Recordset(记录集)来获取唯一并将其填充到组合框。 示例数据如下图1所示。工作表中有一个组合框,需要包含列A省份列表,但是列A中有很多重复省份数据。 ?...单击功能区“开发工具”选项卡“插入”按钮下ActiveX控件“组合框”,工作表插入一个组合框,可以看到Excel将其自动命名为“ComboBox1”,如下图2所示。 ?...图4 3.可以使用如下所示命名区域代替硬编码单元格区域: Myrecordset.Open “Select Distinct [省份] from [命名区域]” 4.可以编写VBA代码遍历数组来获取唯一...3.Extended Properties:当连接到Excel工作簿时使用。告诉VBA数据源来自数据库。

5.5K10

Python直接改变实例化对象列表属性 导致flask接口多次请求报错

(One.get_list()) # [1, 2, 3, 5] 解决方法:调用One.get_copy_list() flask,知识点:一个请求 进入到进程后,会从进程 App中生成一个新app...(在线程应用上下文,改变其会改变进程App相关,也就是进程App指针引用,包括g,),以及生成一个新请求上下文(包括session,request)。...并把此次请求需要应用上下文和请求上下文通过dict格式传入到  栈(从而保证每个请求不会混乱)。并且在请求结束后,pop此次相关上下文。...错误接口代码大致如下: class 响应如下(每次请求,都会向model类列表属性添加元素,这样会随着时间增长导致内存消耗越来越大,最终导致服务崩溃): ?...总结:刚开始以为 一次请求过程,无论怎么操作都不会影响到其他请求执行,当时只考虑了 请求上下文中不会出现这种问题,但是 应用上下文,是 进程App相关属性或常量一个引用(相当于指针),任何对应用上下文中改变

5K20

Python操控Excel使用Python主文件添加其他工作簿数据

标签:Python与Excel,合并工作簿 本文介绍使用Python向Excel主文件添加新数据最佳方法。该方法可以保存主数据格式和文件所有内容。...安装库 本文使用xlwings库,一个操控Excel文件最好Python库。...终端使用下面的命令安装: pip install xlwings 示例文件 本文用到了两个示例Excel工作簿: 主文件.xlsx 新数据.xlsx 可以到知识星球App完美Excel社群下载。...3.想要在每个工作表最后一行下面的空行开始添加数据。如图2所示,“湖北”工作表,是第5行开始添加新数据。 使用Python很容易获取所有Excel工作表,如下图3所示。...这里,要将新数据放置紧邻工作表最后一行下一行,例如上图2第5行。那么,我们Excel是如何找到最后一个数据行呢?

7.8K20

测试驱动之excel文件自动化使用(十二)

一般性,数据存储excel,也是一种选择,但是必须安装对应库,要不python是无法操作excel文件,安装第三方库为为xlrd,安装命令为: pipinstall xlrd 安装过程见截图...excel文件,cell是单元格,sheet是工作表,一个工作表由N个单元格来组成。...我把读取excel数据写成一个函数,先导入xlrd库,然后创建book,以及获取sheet对象,依次获取sheet对象数据,如上excel数据,如果我想获取“请你填写密码”,那么直接调用该函数...文件自动化引用,测试点分别为: 1、输入百度账号,未输入百度密码,点击登陆,验证返回错误信息; 2、输入错误百度账号密码,点击登录,验证返回错误信息; 我们读excel文件函数,登录百度函数写在...,存储excel,然后利用xlrd模块来读取excel数据,达到测试代码与数据分离。

1.8K30

如何使用Excel将某几列有标题显示到新列

如果我们有好几列有内容,而我们希望新列中将有内容标题显示出来,那么我们怎么做呢? Excel - TEXTJOIN function 1....Stackoverflow - Finding a specific value and returning column headers in Excel EXAMPLE: Indexing Year...- - - - 4 - - - 开始,我们曾经使用INDEX + MATCH方式,但是没有成功,一直是N/A https://superuser.com/questions/1300246/if-cell-contains-value-then-column-header...所以我们后来改为TEXTJOIN函数,他可以显示,也可以显示标题,还可以多个列有时候同时显示。...则: =TEXTJOIN(", ",TRUE,IF(ISNUMBER(B2:I2),B2:I2,"")) 其中,ISNUMBER(B2:I2)是判断是不是数字,可以根据情况改成是不是空白ISBLANK

11.3K40

VBA专题10-19:使用VBA操控Excel界面之在功能区添加不同类型自定义控件

添加该控件步骤与前面文章介绍相同,新建一个启用宏工作簿并保存,关闭该工作簿,然后CustomUI Editor打开该工作簿,输入下面的XML代码: ? ? ? ? ? ?...Excel打开该工作簿,然后打开VBE,插入一个标准VBA模块,输入下面的代码: 'Callback for button1 onAction Sub Macro1(control As IRibbonControl...该工作簿自定义选项卡不同类型控件如下图所示: ? 下图演示了自定义选项卡各类控件效果: ?...说明:本专题系列大部分内容学习整理自《Dissectand Learn Excel VBA in 24 Hours:Changingworkbook appearance》,仅供学习研究。...注:如果你有兴趣,你可以到知识星球App完美Excel社群下载这本书完整中文版电子书。 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。

1.8K10
领券