ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 两列数据比较问题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2020-1-5 22:42 | 显示全部楼层 |阅读模式
麻烦大神帮帮忙。I=D-H,如果I>0则A:D插入行;I<0则F:H插入行;I=0,则比较下一行。

Book2.zip

375.17 KB, 下载次数: 6

TA的精华主题

TA的得分主题

发表于 2020-1-6 08:11 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
Sub 按钮1_Click()
    Application.ScreenUpdating = False
    Application.Calculation = xlManual
    r = Cells(Rows.Count, 9).End(3).Row
    arr = [a1].Resize(r, 9)
    For j = UBound(arr) To 2 Step -1
        If arr(j, 9) > 0 Then
            Cells(j, 1).Resize(1, 4).Insert
        Else
            If arr(j, 9) < 0 Then
                Cells(j, 6).Resize(1, 3).Insert
            End If
        End If
    Next j
    Application.Calculation = xlAutomatic
    Application.ScreenUpdating = True
End Sub

TA的精华主题

TA的得分主题

发表于 2020-1-6 08:12 | 显示全部楼层
附件内容,楼主看下理解的对不对吧

Book2.zip

436.4 KB, 下载次数: 8

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-1-7 21:49 | 显示全部楼层
很抱歉,可能是我的表达不够清晰。我想要的结果如附图
原始数据.png
运行结果.png

TA的精华主题

TA的得分主题

发表于 2020-1-8 00:14 | 显示全部楼层
1、先不说你你描述,你不觉得你这几个数据有七百多k很不正常吗?不觉得打开特别卡吗?按下筛选,都到XFZ列(16372列)了。给你精简了。
2、不要惜字如金,说的不明不白,只能猜。不知道你移动下来的那部分要怎么搞,看下附件效果吧,提供两种方案。
  1. Sub 插入1()
  2. '这是根据版主大大的改的,正向循环了
  3.     Application.ScreenUpdating = False
  4.     Application.Calculation = xlManual
  5.     r = Cells(Rows.Count, 4).End(3).Row
  6.     arr = [a1].Resize(r, 9)
  7.     For j = 2 To r 'UBound(arr) ' To 2 Step -1
  8.         If Sheet1.Cells(j, 4) - Sheet1.Cells(j, 8) > 0 Then
  9.             Cells(j, 1).Resize(1, 4).Insert
  10.         Else
  11.             If Sheet1.Cells(j, 4) - Sheet1.Cells(j, 8) < 0 Then
  12.                 Cells(j, 6).Resize(1, 3).Insert
  13.             End If
  14.         End If
  15.     Next j

  16. r = Cells(Rows.Count, 6).End(3).Row
  17. For j = 2 To r
  18. Sheet1.Cells(j, 9) = Sheet1.Cells(j, 4) - Sheet1.Cells(j, 8)
  19. Next

  20.     Application.Calculation = xlAutomatic
  21.     Application.ScreenUpdating = True
  22. End Sub


  23. Sub 插入2()
  24. '本来也想循环的,但是实在不知道怎么重新给循环截止次数重新赋值,有会的老师指导一下吗?
  25. Application.ScreenUpdating = False
  26. Application.Calculation = xlManual
  27.     r = Cells(Rows.Count, 4).End(3).Row
  28.     arr = [a1].Resize(r, 9)
  29.     a = 2
  30.     f = 2
  31. x:
  32.     If Sheet1.Cells(a, 4) - Sheet1.Cells(a, 8) > 0 Then
  33.         Cells(a, 1).Resize(1, 4).Insert
  34.         a = a + 1
  35.         x = x + 1
  36.     Else
  37.         If Sheet1.Cells(a, 4) - Sheet1.Cells(a, 8) < 0 Then
  38.             Cells(a, 6).Resize(1, 3).Insert
  39.             f = f + 1
  40.         End If
  41.     End If
  42.     a = a + 1
  43.     f = f + 1
  44. If a > r + x Then
  45.     GoTo y
  46.     Else
  47.     GoTo x
  48. End If

  49. y:
  50. r = Cells(Rows.Count, 6).End(3).Row
  51. For j = 2 To r
  52. Sheet1.Cells(j, 9) = Sheet1.Cells(j, 4) - Sheet1.Cells(j, 8)
  53. Next

  54. Application.Calculation = xlAutomatic
  55. Application.ScreenUpdating = True
  56. End Sub
复制代码

Book2.zip

17.93 KB, 下载次数: 7

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-1-8 20:33 | 显示全部楼层
格物郅知 发表于 2020-1-8 00:14
1、先不说你你描述,你不觉得你这几个数据有七百多k很不正常吗?不觉得打开特别卡吗?按下筛选,都到XFZ列 ...

第二种方案就是理想的结果,非常感谢。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-4-27 04:33 , Processed in 0.038595 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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