2020年萌软在excel中推出了let和lambda函数,后者可以将自定义函数写在名称管理器中,如果录入了大批量的自定义函数,需要转移到其他文档中,涉及名称管理器的批量导出导入问题。萌软并未提供图形界面的批量处理方法,目前方法主要有两种。
方法一
使用xml文件的特点进行处理。
已填有名称和公式的xlsm文件,扩展名xlsm改为zip。
使用winrar打开,找到xlworkbook.xml。
打开后,在<calcPr calcId=之前,选中<definedNames>至</definedNames>的部分,复制,将空白的xlsm文档改为zip,打开同名文件,粘贴入这段代码,相当于批量导入。保存,扩展名改为xlsm。其中类似<definedName name="fx">EVALUATE(Sheet1!$B$1)</definedName>的内容,包含名称及公式。
该方法在网上没有看到过相关介绍,这几天我刚测试成功。
方法二
A列是名称,B列是函数,用于批量导入到名称管理器中。
Sub 批量导入()
On Error Resume Next
For k = 1 To Range("a" & Rows.Count).End(3).Row
ActiveWorkbook.Names.Add Name:=Cells(k, 1).Value, RefersTo:=Cells(k, 2).Value
Next
End Sub
http://club.excelhome.net/thread-1149999-2-1.html
Sub 批量删除1()
For i = 1 To ActiveWorkbook.Names.Count: ActiveWorkbook.Names(1).Delete
Next
End Sub
http://club.excelhome.net/thread-949053-1-1.html
不过经过测试发现该方法有缺点,不支持部分函数,如EVALUATE等,研究以后发现,需要改为ActiveWorkbook.Names.Add Name:="fx", RefersToR1C1:="=EVALUATE(Sheet1!R1C2)",故缺乏通用性,不如直接使用方法一。