我们都知道当数据过多的时候,我们制作Excel图表就会显得非常的复杂,图表上面的内容就会特别多。Excel老玩家就会想到用切片器制作动态可变化的图表来显示。今天我们就来学习一下一个比......
2023-01-08
请罗列“四川省”、“湖南省”、“湖北省”三个省份员工的资料。
VBA代码如下:
Sub test()
‘定义变量
Dim rng As Range, RngTemp As Range, firstAddress As String
Dim i As Byte, findCell As Range, sh As Worksheet, shtname As String
‘将查找的目标设置为C2单元格到C列最后一个非空单元格赋予变量为rng
Set rng = Range([C2], Cells(Rows.Count, "C").End(xlUp))
‘循环赋予查找数组的每一个元素
For i = 0 To UBound(Array("四川省", "湖南省", "湖北省"))
‘开始查找数据,按值精确查找,不区分大小写
Set RngTemp = rng.Find(What:=Array("四川省", "湖南省", "湖北省")(i), LookIn:=xlValues, lookat:=xlWhole, MatchCase:=False)
‘ 如果找到目标,则赋予该目标的单元格地址给firstAddress
If Not RngTemp Is Nothing Then
firstAddress = RngTemp.Address
Do
‘变量findCell没有初始化,则需要初始化,否则合并查找到的数值
If findCell Is Nothing Then
Set findCell = RngTemp
Else
Set findCell = Union(findCell, RngTemp)
End If
‘查找下一个
Set RngTemp = rng.FindNext(RngTemp)
‘循环到不为第一个找到的目标地址为止
Loop While RngTemp.Address <> firstAddress
End If
Next i
‘如果查找的内容不为空,则选择查找到内容所在行,否则显示提醒
If Not findCell Is Nothing Then
findCell.EntireRow.Select
Else
MsgBox "没有找到符合条件的数据!"
Exit Sub
End If
‘防止错误
On Error Resume Next
‘把当前工作表的名称赋予shtname
shtname = ActiveSheet.Name
Set sht = Sheets("查询结果")
‘如果不存在查询结果表,则添加一个“查询结果”工作表
If Err.Number <> 0 Then
Sheets.Add after:=Sheets(Sheets.Count)
Sheets(Sheets.Count).Name = "查询结果"
Else
Sheets(Sheets.Count).Cells.Clear
End If
Sheets(shtname).Select
Selection.Copy Sheets(Sheets.Count).[A1]
End Sub
相关文章
我们都知道当数据过多的时候,我们制作Excel图表就会显得非常的复杂,图表上面的内容就会特别多。Excel老玩家就会想到用切片器制作动态可变化的图表来显示。今天我们就来学习一下一个比......
2023-01-08
在工作中,可能许多朋友都会碰到一个情况,那就是工作簿和工作表数据的合并操作。如何将上百个工作簿快速合并到一个表格中,许多朋友可能会觉得不可思议。今天我们就来教大家学习一......
2023-01-08
今天在这里为你分享5个Excel文本函数,这些拆分和组合函数,你一定会用上的。①LEFT函数公式:=LEFT(A2,1)在Excel表格中,需要想要拆分汉字,想从哪里开始就从那哪里开始。首先选定单元格......
2023-01-08
相信大家也和我一样,才开始看到Excel可以当做翻译软件的时候会很好奇,这究竟是怎样做到的?其实,这个方法并不是很难,它是由一个函数公式而制作出来的,好了,首先我们一起来看看成......
2023-01-08
函数可以说是所用快捷方法中最为简单的一种方法,为什么很多人认为函数用起来很难了?主要是因为它拥有很长的函数公式,记不住。其实不管是学Excel函数,还是学习其他的一些快捷方法......
2023-01-08