ExcelHome技术论坛

 找回密码
 免费注册
QQ登录 只需一步,快速开始
   
高效办公必会的Office99uu优优 永久免费,网表让Excel秒变数据库 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
Excel不给力? 何不试试FoxTable! 国内首部Excel函数公式学习大典 职场充电黑科技, Office微99uu优优 免费下载Excel行业应用视频
300集Office 2010微99uu优优 Tableau-数据可视化工具 突破Excel限制,用活字格提高效率 12门Excel免费公开课任你学
你的Excel 201099uu优优学习锦囊 欲罢不能, 过目难忘的 Office 新界面 免费的Excel考勤计算系统
查看: 187|回复: 10
打印 上一主题 下一主题

[求助] 优化C列公式的代码,提高运算速度

[复制链接]
TA的精华主题TA的得分主题
跳转到指定楼层
1
发表于 2018-1-13 10:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 玉阳山人 于 2018-1-14 00:01 编辑

各位老师:请看附件: 优化C列公式的代码.zip (821.13 KB, 下载次数: 28)
     按里面的要求优化C列自定义函数代码,让它像B列那样速度飞快。多谢了!函数公式:
     假如数据源在C列,则求间隔值的数组公式是:=IF($C5<>"",IFERROR(SUM(N(FREQUENCY(OFFSET($C5,,,-ROW()+3+MATCH(,-1/($C$4:$C4=$C5))),ROW(INDIRECT("1:"&K$3【C列最大值】))-1)>0)),""),"")


像B列公式一样,修改为:{ =JIANGE(指定区域)}的区域数组公式。比如:AA列公式为{=JIANGE(Z$4:Z35000)},则在Z5:Z35000预先输入公式 ,Z列新数据增加到哪一行,AA列公式自动显示计算结果到哪一行,Z列未输入数据的行,AA列则显示空白。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 有用有用 无用无用
TA的精华主题TA的得分主题
2
 楼主| 发表于 2018-1-13 12:09 | 只看该作者 |楼主
本帖最后由 玉阳山人 于 2018-1-13 12:13 编辑

假如数据源在C列,则求间隔值的数组公式是:=IF($C5<>"",IFERROR(SUM(N(FREQUENCY(OFFSET($C5,,,-ROW()+3+MATCH(,-1/($C$4:$C4=$C5))),ROW(INDIRECT("1:"&K$3【C列最大值】))-1)>0)),""),"")
TA的精华主题TA的得分主题
3
 楼主| 发表于 2018-1-13 13:07 | 只看该作者 |楼主
TA的精华主题TA的得分主题
4
 楼主| 发表于 2018-1-13 13:43 | 只看该作者 |楼主
有老师帮忙写了代码:
Option Explicit

Sub test()
  Dim arr, i, j, t
  t = Timer
  arr = Range("a4:a" & Cells(Rows.Count, "a").End(xlUp).Row)
  ReDim brr(1 To UBound(arr, 1), 1 To 1)
  For i = UBound(arr, 1) To 2 Step -1
    For j = i - 1 To 1 Step -1
      If arr(i, 1) = arr(j, 1) Then
        brr(i - 1, 1) = i - j - 1
        Exit For
      End If
  Next j, i
  [c5].Resize(UBound(brr, 1) - 1, 1) = brr
  Debug.Print Timer - t
End Sub





哪位老师能修改成根据需要任意引用数据源的自定义函数JIANGE(指定区域),最好是区域数组函数公式。
TA的精华主题TA的得分主题
5
 楼主| 发表于 2018-1-13 16:18 | 只看该作者 |楼主
TA的精华主题TA的得分主题
6
 楼主| 发表于 2018-1-13 20:06 | 只看该作者 |楼主
TA的精华主题TA的得分主题
7
发表于 2018-1-13 20:21 | 只看该作者
谁让你用 自定义函数的 ,这样大的表  一定要用 VBA.
TA的精华主题TA的得分主题
8
 楼主| 发表于 2018-1-13 20:32 | 只看该作者 |楼主
丢丢表格 发表于 2018-1-13 20:21
谁让你用 自定义函数的 ,这样大的表  一定要用 VBA.

老师:VBA能不能根据需要任意引用其它列的数据源?一个工作表内的好几列【事先无法确定列标】都要用到JIANGE()函数。我看B列的自定义函数DPBCF()运算速度就很快啊。
TA的精华主题TA的得分主题
9
 楼主| 发表于 2018-1-14 14:05 | 只看该作者 |楼主
TA的精华主题TA的得分主题
10
 楼主| 发表于 2018-1-14 17:54 | 只看该作者 |楼主
各位老师:各位好友:我对VBA是个门外汉,不明白B列的DPBCF()自定义函数用起来又快又方便,比函数公式爽多了!可C列的JIANGE()为什么运行特别慢,远没有函数公式快?是什么原因?
       如果实在无法优化求间隔值的代码运行速度,请告诉无法优化的原因。多谢了!
您需要登录后才可以回帖 登录 | 免费注册
本版积分规则
关闭

最新热点上一条 /1 下一条

关注官方微信,每天坐享新鲜教程
手机版|关于我们|联系我们|ExcelHome    GMT+8, 2018-1-18 19:51 , Processed in 0.066587 second(s), 9 queries , Gzip On, MemCache On.
Powered by Discuz! X3.3 © 2001-2017 Wooffice Inc.
    沪公网安备 31011702000001号 沪ICP备11019229号 本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:徐怀玉律师 李志群律师
快速回复 返回顶部 返回列表
99uu优优