本篇文章给大家带来了关于excel的相关知识,其中主要整理了如何将多个工作表的函数计算结果转换为数值的相关问题,包括了单个工作表的公式转数值、多个工作表的公式转数值,多个工作簿的公式转数值等等内容,下面一起来看一下,希望对大家有帮助。
相关学习推荐:excel教程
如何将多个工作表的函数计算结果转换为数值?今天就给大家集中聊一下这类问题。根据操作范围,这可以分为三种情况。
单个工作表的公式转数值
多个工作表的公式转数值
多个工作簿的公式转数值
1. 区域公式转数值先来说第一种情况,区域函数计算结果转数值。这种最为常见,操作也比较简单。复制目标区域,右键选择性粘贴为数值即可。
操作动画演示如下:
2. 多工作表公式转数值如果是将当前工作簿所有工作表的公式转换为数值,需要使用到vba代码。参考代码如下:
sub functiontransvalue_sheets()dim sht as worksheetfor each sht in worksheets '遍历工作表sht.usedrange.value = sht.usedrange.valuenextend sub
第3行至第5行代码遍历工作表,第4行代码将单元格的值修改为值,也就去除了公式内容。
3. 多工作簿公式转数值指定文件夹下多个工作簿的公式转数值,可以复制运行以下代码:
sub functiontransvalue_workbooks() '全部工作簿dim strpath as string, sht as worksheetdim strwbname as string, wb as workbookwith application.filedialog(msofiledialogfolderpicker) '获取文件夹路径if .show then strpath = .selecteditems(1) & "\" else exit subend withon error resume nextwith application.screenupdating = false '取消屏幕刷新.displayalerts = false '取消警告信息.enableevents = false '取消事件.calculation = xlcalculationmanual '取消公式重算.asktoupdatelinks = false '取消外链询问end withstrwbname = dir(strpath & "*.xls*")do while strwbname <> "" 'dir语句遍历excel文件if strwbname <> thisworkbook.name thenset wb = workbooks.open(strpath & strwbname) '打开工作簿for each sht in wb.worksheets '遍历工作表公式转数值sht.usedrange.value = sht.usedrange.valuenextwb.close true '保存关闭工作簿end ifstrwbname = dir() '下一个excel文件loopwith application '恢复系统设置.screenupdating = true.displayalerts = true.enableevents = true.calculation = xlcalculationautomatic.asktoupdatelinks = trueend withif err.number thenmsgbox err.descriptionelsemsgbox "转换完成。"end ifend sub
代码解析如下
第4至第6行代码允许用户选择目标文件夹,并获取文件夹的路径。
第8至第14行代码取消一系列系统设置。
第15至第25行代码使用条件循环语句+dir函数遍历工作簿。第19至第21行代码再遍历工作表,将公式转换为数值。
第26至第32行代码恢复一系列系统设置。
第33行至第37行代码反馈程序运行结果。
相关学习推荐:excel教程
以上就是excel将多个工作表的函数计算结果转换为数值的详细内容。