vba中 find函数每个参数的详细解释

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vba中 find函数每个参数的详细解释相关的知识,希望对你有一定的参考价值。


参数LookIn是可选的,信息类型。什么信息类型?参数LookAt是可选的,可为XlLookAt常量的xlWhole 或xlPart之一。后边的xllookat常量是什么意思

    <单元格区域>,必须指定,返回一个Range对象。

    参数What,必需指定。代表所要查找的数据,可以为字符串、整数或者其它任何数据类型的数据。对应于“查找与替换”对话框中,“查找内容”文本框中的内容。

    参数After,可选。指定开始查找的位置,即从该位置所在的单元格之后向后或之前向前开始查找(也就是说,开始时不查找该位置所在的单元格,直到Find方法绕回到该单元格时,才对其内容进行查找)。所指定的位置必须是单元格区域中的单个单元格,如果未指定本参数,则将从单元格区域的左上角的单元格之后开始进行查找。

    参数LookIn,可选。指定查找的范围类型,可以为以下常量之一:xlValues、xlFormulas或者xlComments,默认值为xlFormulas。对应于“查找与替换”对话框中,“查找范围”下拉框中的选项。

    参数LookAt,可选。可以为以下常量之一:XlWhole或者xlPart,用来指定所查找的数据是与单元格内容完全匹配还是部分匹配,默认值为xlPart。对应于“查找与替换”对话框中,“单元格匹配”复选框。

    参数SearchOrder,可选。用来确定如何在单元格区域中进行查找,是以行的方式(xlByRows)查找,还是以列的方式(xlByColumns)查找,默认值为xlByRows。

拓展资料:

Find函数用来对原始数据中某个字符串进行定位,以确定其位置。Find函数进行定位时,总是从指定位置开始,返回找到的第一个匹配字符串的位置,而不管其后是否还有相匹配的字符串。

    中文名

    find函数

    外文名

    foundion

    语    法

    find_text

使用语法

FIND(find_text,within_text,start_num)

Find_text 是要查找的字符串。

Within_text 是包含要查找关键字的单元格。就是说要在这个单元格内查找关键字

Start_num 指定开始进行查找的字符数。比如Start_num为1,则从单元格内第一个字符开始查找关键字。如果忽略 start_num,则假设其为 1。

注意

使用 start_num 可跳过指定数目的字符。例如,假定使用文本字符串“AYF0093.YoungMensApparel”,如果要查找文本字符串中说明部分的第一个“Y”的编号,则可将 start_num 设置为 8,这样就不会查找文本的序列号部分。FIND 将从第 8 个字符开始查找,而在下一个字符处即可找到 find_text,于是返回编号 9。FIND 总是从 within_text 的起始处返回字符编号,如果 start_num 大于 1,也会对跳过的字符进行计数。

如果 find_text 是空文本 (),则 FIND 则会返回数值1。

Find_text 中不能包含通配符。

如果 within_text 中没有 find_text,则 FIND返回错误值 #VALUE!。

如果 start_num 不大于 0,则 FIND返回错误值 #VALUE!。

如果 start_num 大于 within_text 的长度,则 FIND 返回错误值 #VALUE!。

参考资料:百度百科:find函数

参考技术A

Find语法:

Range.Find(What,After,LookIn,LookAt,SearchOrder,SearchDirection,MatchCase,MatchByte,SearchFormat)()

What:唯一一个必选参数,含义为需要查询的内容,特点为变体类型,可以接受数字,字符串,日期等数据类型

此外,该参数可以接受通配符。

常用通配符

?一个任意字符,比如?a?可以表示bac aaa等

!任意多个任意字符(包括0个),比如*a*可以表示123aadd23, ade,a等

MatchCase: 是否匹配大小写字母,True-大小写视作不同,False-大小写视作相同

LookAt:匹配单元格,取值:1代表单元格的内容必须与欲查找内容长度相同,不能多出字符

2单元格的内容只需包含欲查找的字符串即可

SearchFormat:是否按照格式查找  true是,false否

扩展资料

Visual Basic for Applications(VBA)是Visual Basic的一种宏语言,是微软开发出来在其桌面应用程序中执行通用的自动化(OLE)任务的编程语言。主要能用来扩展Windows的应用程序功能,特别是Microsoft Office软件。也可说是一种应用程式视觉化的Basic 脚本。

该语言于1993年由微软公司开发的的应用程序共享一种通用的自动化语言--------Visual Basic For Application(VBA),实际上VBA是寄生于VB应用程序的版本。微软在1994年发行的Excel5.0版本中,即具备了VBA的宏功能。

参考技术B FIND(find_text,within_text,start_num)
Find_text 要查找的文本。
Within_text 包含要查找文本的文本。
Start_num 指定要从其开始搜索的字符。within_text 中的首字符是编号为 1 的字符。如果省略 start_num,则假设其值为 1。

=FIND("M",Miriam McGovern) 上面字符串中第一个“M”的位置 (1)
=FIND("m",Miriam McGovern) 上面字符串中第一个“m”的位置 (6)
=FIND("M",Miriam McGovern,3) 在上面字符串中从第三个字符开始查找第一个“M”的位置 (8)追问

看清楚哦 我问的是VBA中哦~~~

追答

1. Find方法的作用
Find方法将在指定的单元格区域中查找包含参数指定数据的单元格,若找到符合条件的数据,则返回包含该数据的单元格;若未发现相匹配的数据,则返回Nothing。该方法返回一个Range对象,在使用该方法时,不影响选定区域或活动单元格。 -------------------------------------------------------------------------------- 2. Find方法的语法 [语法]
.Find (What,[After],[LookIn],[LookAt],[SearchOrder],[SearchDirection],[MatchCase],[MatchByte],[SearchFormat]) [参数说明]
(1),必须指定,返回一个Range对象。
(2)参数What,必需指定。代表所要查找的数据,可以为字符串、整数或者其它任何数据类型的数据。对应于“查找与替换”对话框中,“查找内容”文本框中的内容。
(3)参数After,可选。指定开始查找的位置,即从该位置所在的单元格之后向后或之前向前开始查找(也就是说,开始时不查找该位置所在的单元格,直到Find方法绕回到该单元格时,才对其内容进行查找)。所指定的位置必须是单元格区域中的单个单元格,如果未指定本参数,则将从单元格区域的左上角的单元格之后开始进行查找。
(4)参数LookIn,可选。指定查找的范围类型,可以为以下常量之一:xlValues、xlFormulas或者xlComments,默认值为xlFormulas。对应于“查找与替换”对话框中,“查找范围”下拉框中的选项。

追问

你的语法部分不完整啊,如果是复制别人的不如直接把链接发过来

本回答被提问者采纳

find 命令详细解释

 

命令格式:
find pathname -options [-print -exec -ok ...]

命令参数:
pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
-print: find命令将匹配的文件输出到标准输出。
-exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形为‘command‘ { } ;,注意{ }和;之间的空格。
-ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

命令选项:
-name 按照文件名查找文件
-perm 按文件权限查找文件
-user 按文件属主查找文件
-group 按照文件所属的组来查找文件。
-type 查找某一类型的文件,诸如:
b - 块设备文件
d - 目录
c - 字符设备文件
l - 符号链接文件
p - 管道文件
f - 普通文件
-size n :[c] 查找文件长度为n块文件,带有c时表文件字节大小
-amin n 查找系统中最后N分钟访问的文件
-atime n 查找系统中最后n*24小时访问的文件
-cmin n 查找系统中最后N分钟被改变文件状态的文件
-ctime n 查找系统中最后n*24小时被改变文件状态的文件
-mmin n 查找系统中最后N分钟被改变文件数据的文件
-mtime n 查找系统中最后n*24小时被改变文件数据的文件
(用减号-来限定更改时间在距今n日以内的文件,而用加号+来限定更改时间在距今n日以前的文件。 )
-maxdepth n 最大查找目录深度
-prune选项来指出需要忽略的目录。在使用-prune选项时要当心,因为如果你同时使用了-depth选项,那么-prune选项就会被find命令忽略
-newer 如果希望查找更改时间比某个文件新但比另一个文件旧的所有文件,可以使用-newer选项。

实例:
(1)查找48小时内修改过的文件
find -atime -2

(2)在当前目录查找 以.log结尾的文件。 ". "代表当前目录
find ./ -name ‘*.log‘

(3)查找/opt目录下 权限为 777的文件
find /opt -perm 777

(4)查找大于1K的文件
find -size +1000c

find -size 1000c 查找等于1000字符的文件
-exec 参数后面跟的是command命令,它的终止是以;为结束标志的,所以这句命令后面的分号是不可缺少的,考虑到各个系统中分号会有不同的意义,所以前面加反斜杠。{} 花括号代表前面find查找出来的文件名。
(5)在当前目录中查找更改时间在10日以前的文件并删除它们(无提醒)
find . -type f -mtime +10 -exec rm -f {} ;

(6)当前目录中查找所有文件名以.log结尾、更改时间在5日以上的文件,并删除它们,只不过在删除之前先给出提示。 按y键删除文件,按n键不删除
find . -name ‘*.log‘ mtime +5 -ok -exec rm {} ;

(7)当前目录下查找文件名以passwd开头,内容包含"pkg"字符的文件
find . -f -name ‘passwd*‘ -exec grep "pkg" {} ;

(8)用exec选项执行cp命令
find . -name ‘*.log‘ -exec cp {} test3 ;
-xargs find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。
实例:
(9)查找当前目录下每个普通文件,然后使用xargs来判断文件类型

find . -type f -print | xargs file

(10)查找当前目录下所有以js结尾的并且其中包含‘editor‘字符的普通文件
find . -type f -name "*.js" -exec grep -lF ‘ueditor‘ {} ;
find -type f -name ‘*.js‘ | xargs grep -lF ‘editor‘

(11)利用xargs执行mv命令
find . -name "*.log" | xargs -i mv {} test4

(12)用grep命令在当前目录下的所有普通文件中搜索hostnames这个词,并标出所在行
find . -name *(转义) -type f -print | xargs grep -n ‘hostnames‘

(13)查找当前目录中以一个小写字母开头,最后是4到9加上.log结束的文件
find . -name ‘[a-z]*[4-9].log‘ -print

(14)在test目录查找不在test4子目录查找
find test -path ‘test/test4‘ -prune -o -print

(15)实例1:查找更改时间比文件log2012.log新但比文件log2017.log旧的文件
find -newer log2012.log ! -newer log2017.log

使用depth选项:
depth选项可以使find命令向磁带上备份文件系统时,希望首先备份所有的文件,其次再备份子目录中的文件。
实例:find命令从文件系统的根目录开始,查找一个名为CON.FILE的文件。 它将首先匹配所有的文件然后再进入子目录中查找
find / -name "CON.FILE" -depth -print






















































以上是关于vba中 find函数每个参数的详细解释的主要内容,如果未能解决你的问题,请参考以下文章

关于VBA的Find函数

find 命令详细解释

vba语言中find 的用法

Excel vba 多个条件查询应该怎么做,可以用find方法吗?

IF FIND 函数在 vba 中找不到任何内容

jQuery中find()方法的疑惑