ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 根据“记账凭证清单”自动生成“日记账”

[复制链接]

TA的精华主题

TA的得分主题

发表于 2021-8-13 14:17 | 显示全部楼层 |阅读模式
本帖最后由 kanny_a 于 2021-8-13 14:18 编辑

求助:
请各位老师帮忙,想要根据录入好的“记账凭证清单”自动生成“日记账”和其他账。
因为不懂VB,请老师帮忙用函数实现。

感谢!


book1.zip

440.2 KB, 下载次数: 23

TA的精华主题

TA的得分主题

发表于 2021-8-14 07:15 来自手机 | 显示全部楼层
这种感觉函数比较难。可以搜一下 生成明细账或者会计财务软件。

TA的精华主题

TA的得分主题

发表于 2021-8-14 09:29 | 显示全部楼层
只做了上一半的公式,看看是不是这个意思

book1.zip

443.24 KB, 下载次数: 15

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2021-8-14 09:36 | 显示全部楼层
  1. Sub test()
  2.   Dim r%, i%
  3.   Dim arr, brr(), lj(1 To 2) As Double
  4.   Application.ScreenUpdating = False
  5.   Application.DisplayAlerts = False
  6.   Dim d As Object
  7.   Set d = CreateObject("scripting.dictionary")
  8.   With Worksheets("日记账")
  9.     km = .Range("i1")
  10.   End With
  11.   m = 1
  12.   With Worksheets("凭证一览表")
  13.     .AutoFilterMode = False
  14.     r = .Cells(.Rows.Count, 1).End(xlUp).Row
  15.     arr = .Range("a3:k" & r)
  16.     ReDim brr(1 To UBound(arr), 1 To 6)
  17.     For i = 1 To UBound(arr)
  18.       If arr(i, 7) = km Then
  19.         m = m + 1
  20.         brr(m, 1) = CDate(arr(i, 1) & "-" & arr(i, 2) & "-" & arr(i, 3))
  21.         brr(m, 2) = arr(i, 5)
  22.         brr(m, 3) = arr(i, 6)
  23.         brr(m, 4) = arr(i, 10)
  24.         brr(m, 5) = arr(i, 11)
  25.       End If
  26.     Next
  27.   End With
  28.   If m = 1 Then
  29.     MsgBox "没有符合条件数据!"
  30.     Exit Sub
  31.   End If
  32.   With Worksheets("期初余额表")
  33.     .AutoFilterMode = False
  34.     r = .Cells(.Rows.Count, 1).End(xlUp).Row
  35.     arr = .Range("a4:e" & r)
  36.     For i = 1 To UBound(arr)
  37.       If arr(i, 1) = km Then
  38.         brr(1, 1) = #1/1/2018#
  39.         brr(1, 3) = "期初余额"
  40.         brr(1, 6) = arr(i, 4) - arr(i, 5)
  41.         Exit For
  42.       End If
  43.     Next
  44.   End With
  45.   For i = 2 To m
  46.     brr(i, 6) = brr(i - 1, 6) + brr(i, 4) - brr(i, 5)
  47.     yf = Month(brr(i, 1))
  48.     If Not d.exists(yf) Then
  49.       ReDim hj(1 To 2)
  50.     Else
  51.       hj = d(yf)
  52.     End If
  53.     hj(1) = hj(1) + brr(i, 4)
  54.     hj(2) = hj(2) + brr(i, 5)
  55.     d(yf) = hj
  56.   Next
  57.   ReDim crr(1 To m + d.Count * 2 + 100, 1 To 6)
  58.   x = 0
  59.   For i = 1 To m
  60.     x = x + 1
  61.     For j = 1 To UBound(brr, 2)
  62.       crr(x, j) = brr(i, j)
  63.     Next
  64.     If Month(brr(i, 1)) <> Month(brr(i + 1, 1)) Then
  65.       x = x + 1
  66.       crr(x, 3) = "本月合计"
  67.       crr(x, 4) = d(Month(brr(i, 1)))(1)
  68.       crr(x, 5) = d(Month(brr(i, 1)))(2)
  69.       lj(1) = lj(1) + d(Month(brr(i, 1)))(1)
  70.       lj(2) = lj(2) + d(Month(brr(i, 1)))(2)
  71.       x = x + 1
  72.       crr(x, 3) = "本年累计"
  73.       crr(x, 4) = lj(1)
  74.       crr(x, 5) = lj(2)
  75.     End If
  76.   Next
  77.   With Worksheets("日记账")
  78.     .UsedRange.Offset(4, 0).Clear
  79.     With .Range("a5").Resize(x, UBound(crr, 2))
  80.       .Value = crr
  81.       .Borders.LineStyle = xlContinuous
  82.       With .Font
  83.         .Name = "Times New Roman"
  84.         .Size = 11
  85.       End With
  86.     End With
  87.     For i = 1 To x
  88.       If crr(i, 3) = "本年累计" Then
  89.         With .Cells(i + 4, 1).Resize(1, 6)
  90.           With .Borders(xlEdgeTop)
  91.             .LineStyle = xlContinuous
  92.             .Color = -16776961
  93.             .Weight = xlThin
  94.           End With
  95.           With .Borders(xlEdgeBottom)
  96.             .LineStyle = xlDouble
  97.             .Color = -16776961
  98.             .Weight = xlThick
  99.           End With
  100.         End With
  101.       End If
  102.     Next
  103.   End With
  104. End Sub
复制代码

评分

3

查看全部评分

TA的精华主题

TA的得分主题

发表于 2021-8-14 09:36 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
详见附件。

Book1.rar

461.41 KB, 下载次数: 40

TA的精华主题

TA的得分主题

发表于 2021-8-14 09:59 | 显示全部楼层
纠正了个小BUG。

Book1.rar

462.01 KB, 下载次数: 38

TA的精华主题

TA的得分主题

发表于 2021-8-14 10:13 | 显示全部楼层
换一种写法。
  1. Sub test2()
  2.   Dim r%, i%, m%
  3.   Dim arr, brr(), hj(1 To 2, 1 To 2) As Double, zrr()
  4.   Application.ScreenUpdating = False
  5.   Application.DisplayAlerts = False
  6.   With Worksheets("日记账")
  7.     km = .Range("i1")
  8.   End With
  9.   m = 1
  10.   With Worksheets("凭证一览表")
  11.     .AutoFilterMode = False
  12.     r = .Cells(.Rows.Count, 1).End(xlUp).Row
  13.     arr = .Range("a3:k" & r)
  14.     ReDim brr(1 To UBound(arr), 1 To 6)
  15.     For i = 1 To UBound(arr)
  16.       If arr(i, 7) = km Then
  17.         m = m + 1
  18.         brr(m, 1) = CDate(arr(i, 1) & "-" & arr(i, 2) & "-" & arr(i, 3))
  19.         brr(m, 2) = arr(i, 5)
  20.         brr(m, 3) = arr(i, 6)
  21.         brr(m, 4) = arr(i, 10)
  22.         brr(m, 5) = arr(i, 11)
  23.       End If
  24.     Next
  25.   End With
  26.   With Worksheets("期初余额表")
  27.     .AutoFilterMode = False
  28.     r = .Cells(.Rows.Count, 1).End(xlUp).Row
  29.     arr = .Range("a4:e" & r)
  30.     For i = 1 To UBound(arr)
  31.       If arr(i, 1) = km Then
  32.         brr(1, 1) = #1/1/2018#
  33.         brr(1, 3) = "期初余额"
  34.         brr(1, 6) = arr(i, 4) - arr(i, 5)
  35.         Exit For
  36.       End If
  37.     Next
  38.   End With
  39.   For i = 2 To m
  40.     brr(i, 6) = brr(i - 1, 6) + brr(i, 4) - brr(i, 5)
  41.   Next
  42.   k = 0
  43.   yf = 0
  44.   For i = 1 To m
  45.     If Month(brr(i, 1)) <> yf Then
  46.       k = k + 1
  47.       ReDim Preserve zrr(1 To 2, 1 To k)
  48.       zrr(1, k) = i
  49.       zrr(2, k) = i
  50.       yf = Month(brr(i, 1))
  51.     Else
  52.       If k > 0 Then
  53.         zrr(2, k) = i
  54.       End If
  55.     End If
  56.   Next
  57.   
  58.   ReDim crr(1 To m + UBound(zrr, 2) * 2, 1 To 6)
  59.   x = 0
  60.   For k = 1 To UBound(zrr, 2)
  61.     hj(1, 1) = 0
  62.     hj(1, 2) = 0
  63.     For i = zrr(1, k) To zrr(2, k)
  64.       x = x + 1
  65.       For j = 1 To UBound(brr, 2)
  66.         crr(x, j) = brr(i, j)
  67.       Next
  68.       hj(1, 1) = hj(1, 1) + brr(i, 4)
  69.       hj(1, 2) = hj(1, 2) + brr(i, 5)
  70.       hj(2, 1) = hj(2, 1) + brr(i, 4)
  71.       hj(2, 2) = hj(2, 2) + brr(i, 5)
  72.     Next
  73.     x = x + 1
  74.     crr(x, 3) = "本月合计"
  75.     crr(x, 4) = hj(1, 1)
  76.     crr(x, 5) = hj(1, 2)
  77.     x = x + 1
  78.     crr(x, 3) = "本年累计"
  79.     crr(x, 4) = hj(2, 1)
  80.     crr(x, 5) = hj(2, 2)
  81.   Next
  82.   
  83.   With Worksheets("日记账")
  84.     .UsedRange.Offset(4, 0).Clear
  85.     With .Range("a5").Resize(x, UBound(crr, 2))
  86.       .Value = crr
  87.       .Borders.LineStyle = xlContinuous
  88.       With .Font
  89.         .Name = "Times New Roman"
  90.         .Size = 11
  91.       End With
  92.     End With
  93.     For i = 1 To x
  94.       If crr(i, 3) = "本年累计" Then
  95.         With .Cells(i + 4, 1).Resize(1, 6)
  96.           With .Borders(xlEdgeTop)
  97.             .LineStyle = xlContinuous
  98.             .Color = -16776961
  99.             .Weight = xlThin
  100.           End With
  101.           With .Borders(xlEdgeBottom)
  102.             .LineStyle = xlDouble
  103.             .Color = -16776961
  104.             .Weight = xlThick
  105.           End With
  106.         End With
  107.       End If
  108.     Next
  109.   End With
  110. End Sub

复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2021-8-14 10:14 | 显示全部楼层
换一种写法,感觉思路清晰了很多。

Book1.rar

468.17 KB, 下载次数: 28

TA的精华主题

TA的得分主题

发表于 2021-8-14 11:50 | 显示全部楼层
又打磨了一遍。

Book1.rar

462.77 KB, 下载次数: 70

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2021-8-14 16:54 | 显示全部楼层
帐簿2.rar (476.87 KB, 下载次数: 27)
untitled2.png
untitled1.png

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-29 01:35 , Processed in 0.036192 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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