ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[已解决] 按要求修改VBA过程的J列公式代码

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-5-20 18:03 | 显示全部楼层 |阅读模式
本帖最后由 13782671637 于 2018-5-20 18:12 编辑

尊敬的各位老师:请看附件 修改VBA过程代码.zip (1.06 MB, 下载次数: 32)   按《2》L2294:L2300里的要求修改代码里计算J列数据的公式代码。L2304:L2335就是需要修改的代码,存放在模块1里。多谢了!

   备注:工作表《0》、《1》、《2》的E:I里的数据,是满足  总表!$J$5:$J$83836=$I$1  指定条件时,总表E:I列的所有数据。

  由于实际工作表里的数据很多,十来万行,所以必须使用运算速度高效的代码!

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 18:17 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
恳请老师们帮忙!

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 18:39 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 20:19 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 21:09 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
恳请大神,恳请高手,恳请老师们帮忙!

TA的精华主题

TA的得分主题

发表于 2018-5-20 21:50 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
  For i = 2 To UBound(brr)
    If brr(i, 1) = 0 Or brr(i, 1) = "" Then
    brr(i, 6) = Range("d1") - brr(i - 1, 1)
    Exit For
    End If
    brr(i, 6) = brr(i, 1) - brr(i - 1, 1)
  Next
这个地方插入几句,就可以实现了,其实可以用动态数组实现的,dim preserve  brr(),
楼主可以自己实现,至于说能不能汇总时更新所有的表我感觉还是可以实现的。

截图

截图

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 21:58 | 显示全部楼层
yanghaipingabc 发表于 2018-5-20 21:50
For i = 2 To UBound(brr)
    If brr(i, 1) = 0 Or brr(i, 1) = "" Then
    brr(i, 6) = Range("d1") ...

老师:哪种代码运算速度快就用哪一种。说实话,如果是函数公式,我还马马虎虎;VBA代码,刚接触几个月,委实不行。麻烦您把修改的代码粘贴进附件的模块1,上传。多谢了!

TA的精华主题

TA的得分主题

发表于 2018-5-20 22:18 | 显示全部楼层
我基本没有改变等你的代码,你可以先试试,动态数组和这次的速度差不多,要是还需要修改可以在联系我QQ373379106

修改VBA过程代码1.zip

1.09 MB, 下载次数: 16

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 22:42 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
yanghaipingabc 发表于 2018-5-20 22:18
我基本没有改变等你的代码,你可以先试试,动态数组和这次的速度差不多,要是还需要修改可以在联系我QQ3733 ...

非常感谢老师的帮助!我已用您6楼修改的代码测试过,计算结果正确、快捷!8楼的代码和6楼前后顺序不大相同【见红色部分】,哪个更好些?

Sub test()
  Dim r&, i&, c&, j&
  Dim arr, brr
  Application.ScreenUpdating = False
  Application.DisplayAlerts = False
  With Worksheets("总表")
    r = .Cells(.Rows.Count, 5).End(xlUp).Row
    arr = .Range("e5:j" & r)
  End With
  With ActiveSheet
    xm = .Range("i1")
  End With
  ReDim brr(1 To UBound(arr), 1 To 6)
  m = 0
  For i = 1 To UBound(arr)
    If arr(i, 6) = xm Then
      m = m + 1
      For j = 1 To 5
        brr(m, j) = arr(i, j)
      Next
    End If
  Next
  For i = 2 To UBound(brr)
    If brr(i, 1) = 0 Or brr(i, 1) = "" Then
    brr(i, 6) = Range("d1") - brr(i - 1, 1)
    Exit For
    End If
    brr(i, 6) = brr(i, 1) - brr(i - 1, 1)

  Next
  With ActiveSheet
    .Range("e5:i" & .Rows.Count).ClearContents
    .Range("e5").Resize(UBound(brr), UBound(brr, 2)) = brr
  End With
  Application.ScreenUpdating = True
  MsgBox "数据计算完毕!"
End Sub

     另外,能不能把0、1、2里的三个按钮合并成一个,在总表里点击一次,则0、1、2工作表的数据就会自动更新?

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-5-20 22:43 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
yanghaipingabc 发表于 2018-5-20 22:18
我基本没有改变等你的代码,你可以先试试,动态数组和这次的速度差不多,要是还需要修改可以在联系我QQ3733 ...

我的QQ是1336602627
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-16 12:35 , Processed in 0.028703 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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