【原创】VBA学习笔记(18) VBA的自定义函数 / 过程,到底能不能改变EXCEL单元格内容?

目录

一 自定义函数

1.1 什么是EXCEL 的自定义函数

1.2 明确概念: 函数错误 Vs 函数返回值错误

二 自定义函数详情总结

2.1 自定义函数总结

2.2 自定义函数问题1:自定义函数命名有玄机,可能造成问题

2.3 自定义函数问题2: 数据类型要匹配,否则可能返回错误

2.4 自定义函数问题3:自定义函数不一定有返回值

2.5 自定义函数问题4:自定义函数不能改变EXCEL的单元格里的值?

三  过程是可以的?

3.1 function不能的,过程可以做哪些?

3.2   function的可以的,sub哪些不可以?

四  原因呢?

五 例外呢

参考的文档 和继续学习


一 自定义函数

1.1 什么是EXCEL 的自定义函数

  • VBA里用户自己写了一些函数,这些非 EXCEL 和 VBA 内置的函数,也可以在EXCEL直接使用
  • VBA的函数在 EXCEL里如何使用?
  • 单元格里输入 = 自定义函数名  即可

1.2 明确概念: 函数错误 Vs 函数返回值错误

  • 函数错误:是 语法错误,允许错误,逻辑错误等等
  • 函数返回值错误:是 函数调用后,返回值报错了。(不一定是函数本身的错误)

二 自定义函数详情总结

2.1 自定义函数总结

  • 1---自定义函数的命名需要注意,有时候,自定义函数不正确是因为 函数命名 有问题
  • 2---自定义函数在excel里使用,最好有返回值!
  •      没有的话也可以,会返回默认值,如0
  • 3---自定义函数,在excel里使用,要注意数据类型是否有问题,比如要求是int的函数,无法处理字符串!
  • (exce l或 VBA的内置函数也一样,比如sum 也无法处理 字符串,sum("a") 也会报错)
  • 4---自定义函数

2.2 自定义函数问题1:自定义函数命名有玄机,可能造成问题

  • 下面2个自定义函数,就函数名不同
  • 推测原因是:函数名冲突
  • 实测:2个字母的很容易出错,函数名长点比如加个test,或者用中文就没问题
  • 实测在EXCEL里输入
  • =SUM2(A1,B1)    返回值会报错,怀疑和 系统内置的函数名有些冲突 sum2?
  • =mysum2(A1,B1)

Function sum2(a As Integer, b As Integer) '怀疑函数名不能用
sum2 = a + b
End Function

Function mysum2(a As Integer, b As Integer)
'Dim a As Integer
'Dim b As Integer
mysum2 = a + b
End Function

2.3 自定义函数问题2: 数据类型要匹配,否则可能返回错误

  • 自定义函数,也要注意,处理的数据的数据类型,如果不合适可能报错
  • 这一点和EXCEL的内置函数一样
  • 虽然sum之类的函数无法处理string
  • 但string 就可以把 5这样的 integer当做字符串处理没问题


Function merge1(m As String, n As String)
merge1 = m & n
End Function


Function cube1(a)
cube1 = a * a * a
End Function

2.4 自定义函数问题3:自定义函数不一定有返回值

  • 自定义函数里没定义 function_name=  赋值,返回,就会返回空值,可以试1个啥也不做的函数
  • 相当于在一个EXCEL 的单元格里引用 自定义函数,因为自定义函数没有返回值,所以单元格的值就显示 #n/a #value
  • 下面这个是因为试图改变单元格的值引起的报错
Function mysum1()
mysum1 = Cells(1, 1).Value + Cells(1, 2).Value
End Function



Function mysum3()  '函数本身在VBA里OK,但这个当自定义函数使用,函数本事没事,但返回值会报错
Cells(10, 1).Value = Cells(1, 1).Value + Cells(1, 2).Value
End Function


Function mysum4()    '改变单元格的值,会返回报错
Cells(10, 1).Value = 100
End Function

Function mysum5()  '没返回值,不会返回报错,但是会返回0
End Function

用function 只干改变EXCEL单元格的值也不行

  • 可能是没有函数返回值引起的问题?NO
  • 还是因为改变EXCEL的单元格的值引起的
  • 怀疑是因为cells()的语法,是在VBA内合法,在EXCEL内并没有cells()这样的写法导致?
Function mysum4()   '这样也会返回错误
Cells(10, 1).Value = 100
End Function

2.5 自定义函数问题4:自定义函数不能改变EXCEL的单元格里的值?

  • 自定义函数,在EXCEL运行也可以改变excel里的单元格的值啊?可以吗?--不行
  • 怀疑是因为cells()的语法,是在VBA内合法,在EXCEL内并没有cells()这样的写法导致?
Function mysum3()
mysum3 = Cells(1, 1).Value + Cells(1, 2).Value
'Cells(10, 1).Value = 100    '这句如果不注释掉,带上就返回错误,真TMD
Rem "function可以改变EXCEL的单元值?--现在测试还是不能啊!!!"

End Function

三  过程是可以的?

3.1 function不能的,过程可以做哪些?

  • 过程可以改变EXCEL的单元格的值?--可以
  • 而且是需要点击运行的

3.2   function的可以的,sub哪些不可以?

  • 过程不能有返回值,
  • sub不能在excel里当自定义函数只有使用,只能 点击运行等

四  原因呢?

但空的可以增加,删除?增删改不能改? 但也能函数处理

这个是为啥?

EXCEL 数据  和VBA代码 隔开安全?

五 例外呢

看不懂的牛逼帖子

[推荐]谁说自定义函数不能修改其它单元格的值-Excel VBA程序开发-ExcelHome技术论坛 -

参考的文档 和继续学习

VBA不能修改已写内容,可以写入单元格_百度知道

自定义函数中如何改变单元格的值?-Excel VBA程序开发-ExcelHome技术论坛 -

这2个需要学习

他山之石——VBA自定义函数_预见未来to50的博客-CSDN博客

[推荐]谁说自定义函数不能修改其它单元格的值-Excel VBA程序开发-ExcelHome技术论坛 -

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目录: 1.返回 Column 英文字 2.查询某一值第num次出现的值 3.返回当个人工资薪金所得为2000元(起征点为850元)时的应纳个人所得税税额 4.从形如"123545ABCDE"的字符串中取出数字 5.从形如"ABCD12455EDF"的字符串中取出数字 6.按SplitType取得RangeName串值中的起始位置 7.将金额数字转成中文大写 8.计算某种税金 9.人民币大、小写转换 10.查汉字区位码 11.把公元年转为农历 12.返回指定列数的列标 13.用指定字符替换某字符 14.从右边开始查找指定字符在字符串中的位置 15.从右边开始查找指定字符在字符串中的位置 16.计算工龄 17.计算日期差,除去星期六、星期日 18.将英文字反转的自定函数 19.计算个人所得税 20.一个能计算是否有重复单元的函数 21.数字金额转中文大写 22.将数字转成英文 23.人民币大小写转换 24.获取区域颜色值 25.获取活动工作表名 26.获取最后一行行数 27.判断是否连接在线 28.币种转换 29.检验工作表是否有可打印内容 30.查找一字符串(withinstr)在另一字符串中(findstr1)中某一次(startnum)出现时的位置,返回零表示没找到。 31.增加文件路径最后的“\”符号 32.计算所得税 33.从工作表第一行的标题文字以数字形式返回所在列号 34.在多个工作表中查找一个范围内符合某个指定条件的项目对应指定范围加总求和 35.返回 Column 英文字 36.查找指定列名的列数 37.文字格式的时间(分:秒)转化为数字格式(秒) 38.将"hh:mm:ss"格式的时分秒数转换成秒数 39.金额中文大写转数字 40.把角度转为度秒分、弧度等显示 41.身份证号码侦测 42.显示公式 43.方便财务人员理帐查找 44.数值转换为字符地址 45.字符地址转换为数值 46.等待时间(以秒计算) 47.得到字符串实际的长度(以单字节记) 48.18位身份证最后一位有效性验证 49.计算符合maturity condition的拆解金额 50.对多个用同一分隔符分隔的待查找元素,逐一在表区域首列内搜索,将返回选定单元格的值相加,相当于多个vlookup函数相加,对于查找不到的元素在批注中添加,以提醒用户。 51.根据个人所得税(工资)反算工资数 52.判断表是否存在 53.角度转弧 54.比较相同的字符串 55.对选定的数组进行排序 56.取得指定月份天数 57.排序工作表活页薄 58.统计数组中非重复数据个数 59.摘取子字符串 60.计算20000余个汉字的笔画 61.删除当前工作表中的全部超连接 62.取得相近数据 63.提取定串中汉字 64.搜索重复数据(选定范围) 65.字符型转数字型 66.小写人民币转大写人民币 67.取得指定月份人星期天个数 68.侦测档案是否包含宏 69.获取循环参照单元格 70.创建桌面快捷方式 71.自动建立多级目录 72.统计经筛选后符合条件的记录条数 73.复制单元格列高与栏宽 74.取消隐藏工作表(包括vba Project工程保护的) 75.删除单元格自定义名称 76.从文件路径中取得文件名 77.取得一个文件的扩展名 78.取得一个文件的路径 79.十进制转二进制 80.检查一个数组是否为空 81.字母栏名转数字栏名 82.数字栏名转文字栏名 83.判断一件活页夹中是否还有子目录 84.判断一个文件是否在使用中 85.列出档案详细摘要信息 86.获取菜单ID编号及名称列表 87.状态列动态显示文字 88.取得一个文件的路径2 89.取得一个文件的路径3 90.取得Activecell的栏名 91.取得单元格中指定字符前的字符 92.前单元格指定字符前的字符颜色改成红色 93.根据数字返回对应的字母列号 94.取工作表名字 95.取消所有隐藏的宏表 96.导出VBA Project代码 97.导入VBA Project代码 98.取得汉字拼音的第一个字母 99.获取两栏中相同的数据 100.选取当前工作表中公式出错的单元格﹐关返回出错个数 101.将工作表中最后一列作为页脚打印在每一面页尾 102.获取vbproject引用项目 103.移除Excel工作表中的外部数据连接 104.将选择定单元格作成镜像图片 105.反选择单元格中的数 106.在Excel中加入一个量度尺(以厘米为单位) 107.在Excel中加入一个量度尺(以寸为单位) 108.取得一个短文件名的长文件名 109.取得临时文件名 110.等用Shell调用的程序执行完成后再执行其它程序 111.将Mouse显示成动画 112.限制Mouse移动范围 113.取得当前激活窗品句柄及标题 114.取得屏幕分辨率 115.自动建立多级目录 116.将文件长度置零 117.读取WIN9X / Me共享文件夹密码 118.取得预设的打印机及设置预设的打印机 119.获得当前操作系统的打印机个数及检测打印是否存在 120.枚举打印机名称清单 121.读取网络服务器当前时间 122.下载文件到指定目录 123.自动映射网络驱动器 124.自动断开网络驱动器 125.连接选定单元格中的内容 126.获取一个单元格中有指定字体颜色部份数据 127.对指定文件加XLS加密 128.选择指定范围内使用了填充颜色的单元格 129.在特定的区域内查找文本,返回值是包含查找文本的单元格 130.返回特定区域中最大值的地址 131.删除表格中使用范围内的所有空白单元格 132.返回数组中有多少个指定的字符串 133.返回当前工作表中引用了指定的单元的地址 134.获取Excel中字型列表 135.获取一个字符串中有多少个数字字符 136.在Excel中对多列进行填充 137.对选定的范围进行数据填充(忽略单元格格式) 138.VBA Project加密及解密 139.列出收藏夹中的网址 140.计算两个日期之间相隔的年份,比如年龄,工龄等.可计算从1000年01月01日起的日期 141.从字符串提取纯数字 142.将一个数组按升序排列 143.将一个数组按降序排列 144.删除空白列 145.判断工作表是否为空白 146.将数据按类分到不同工作薄 147.单元格内数据排序 148.对多栏排序 149.返回计算公式的值 [,值的计算公式] 150.把第一列=某个值对应的第二列的内容连在一起,并用、隔开 151.取得系统使用模式 152.计算机注销/关机/重启 153.更改计算机名称 154.从n位开始取出字符串中的汉字、英文字母、数字 155.在指定列中寻找含有指定字符串的单元格,并将符合条件的单元格标为红色,并将对应的下一列单元格赋值为1 156.清除字符串中的空格 157.查找合并单元格位置 158.阴阳历转换和阴阳历生日 159.利用数组和Substitute来替换某字符 160.一键创建斜线表头 161.自动获取指定月的工作日
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值