ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 972|回复: 11

[已解决] 如何自定义函数(功能为将字符串中的数字提取出来并计算)

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-4-4 17:27 | 显示全部楼层 |阅读模式
本帖最后由 cdcxzj 于 2023-4-4 19:01 编辑

问题:请问大佬们,如果通过自定义函数,实现将单元格中的数字提取出来并求和;
实际情况:如在流水账中,某单元格中含各明细(事项与费用),现需对数字进行求和计算;
目前进度:网上查找了一些代码并修改,目前只能对指定单元格(B2)计算,结果在指定单元格显示(B3)
请大神们指正:怎么样将此代码设置为自定义函数,对任何指定单元格均实际计算   如: B4=Tsum(e8)
11111111.jpg

数字计算(单元格含字符,数字需提取).rar

16.96 KB, 下载次数: 6

TA的精华主题

TA的得分主题

发表于 2023-4-4 18:11 | 显示全部楼层
原理:
1、利用正则去除字符串中的数字,包含小数点(当然上面的函数没有考虑负数)
2、利用Application.Trim的特性:若连续空格,只保留一个空格
3、利用Evaluate计算字符串。

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2023-4-4 18:06 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
111.jpg

TA的精华主题

TA的得分主题

发表于 2023-4-4 18:07 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
请参考附件
数字计算(单元格含字符,数字需提取).rar (15.44 KB, 下载次数: 13)

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-4 18:57 | 显示全部楼层
yylucke 发表于 2023-4-4 18:11
原理:
1、利用正则去除字符串中的数字,包含小数点(当然上面的函数没有考虑负数)
2、利用Application. ...

完美实现!!!谢谢您!~~~
结贴了@!~

TA的精华主题

TA的得分主题

发表于 2023-4-6 12:49 | 显示全部楼层
yylucke 发表于 2023-4-4 18:11
原理:
1、利用正则去除字符串中的数字,包含小数点(当然上面的函数没有考虑负数)
2、利用Application. ...

老师您好!
请你帮忙:下面是我录制的宏的内容,单独运行没有问题。
    Sheets("成绩查询").Select
    Range("AA5:AA69").Select
    Selection.Copy '复制文本
    Range("Z5").Select
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=F
alse, Transpose:=False '粘贴数值
    Range("Z5").Select
可是我加一个工作表事件,为什么就运行不了?
Private Sub Worksheet_Change(ByVal Target As Range) '工作表触发事件
    Set Myrng = Range("A1")   
    Sheets("成绩查询").Select
    Range("AA5:AA69").Select'老是从这个地方开始卡住了
    Selection.Copy '复制文本
    Range("Z5").Select
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False '粘贴数值
    Range("Z5").Select
End Sub

TA的精华主题

TA的得分主题

发表于 2023-4-14 09:40 | 显示全部楼层
改进了一点,可以计算负数
Function TQSUM(txt$)
    With CreateObject("VBScript.RegExp")
        .Global = True
        .Pattern = "(-?[0-9.]+)"
        Set mh = .Execute(txt)
        For k = 0 To mh.Count - 1
            TQSUM = TQSUM + Val(mh(k).SubMatches(0))
        Next
    End With
    Set mh = Nothing
End Function

TA的精华主题

TA的得分主题

发表于 2023-4-14 09:49 | 显示全部楼层
zyhui1961 发表于 2023-4-6 12:49
老师您好!
请你帮忙:下面是我录制的宏的内容,单独运行没有问题。
    Sheets("成绩查询").Select

89898989.jpg


你在前后增加:
Application.EnableEvents = False
你的代码
……………………
Application.EnableEvents = True

TA的精华主题

TA的得分主题

发表于 2023-4-14 10:00 | 显示全部楼层
yylucke 发表于 2023-4-14 09:49
你在前后增加:
Application.EnableEvents = False
你的代码

帮忙改一下呗,谢谢了!!!

TA的精华主题

TA的得分主题

发表于 2023-4-14 10:21 | 显示全部楼层
E3//一般公式//
=SUMPRODUCT(--(0&TRIM(MID(E2,ROW($1:$100),TEXT(FREQUENCY(-ROW($1:$99),-ISERR(-(0&MID(0&E2,ROW($1:$99),1)))*ROW($1:$99))-1,"[<]!0")))))
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-17 15:39 , Processed in 0.038362 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表