Foxtable(狐表)用户栏目专家坐堂 → 明细账余额计算


  共有1677人关注过本帖树形打印复制链接

主题:明细账余额计算

帅哥哟,离线,有人找我吗?
实话实说
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
明细账余额计算  发帖心情 Post By:2023/12/22 15:35:00 [显示全部帖子]

这个明细账表的余额如何根据总账科目和明细科目分类计算?类似流水账,余额 = 余额(上1行) + 借方 - 贷方

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:明细账.foxdb


 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/22 16:41:00 [显示全部帖子]

这样吗?不行啊。

Select Case e.DataCol.Name
    Case "总账科目","明细科目","借方","贷方"
        Dim dr As DataRow
        Dim mr As DataRow = e.DataRow
        Dim drs As List(of DataRow)
        dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [总账科目] = '" & mr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "'", "[_SortKey] Desc")
        If dr Is Nothing Then
            mr("余额") = mr("借方") - mr("贷方")
            dr = mr
        End If
        drs = e.DataTable.Select("[_SortKey] >= " & dr("_SortKey") & " And [总账科目] = '" & dr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "'", "[_SortKey]")
        For i As Integer = 1 To drs.Count - 1
            drs(i)("余额") = drs(i-1)("余额") + drs(i)("借方") - drs(i)("贷方")
        Next
        If e.DataCol.Name = "总账科目" AndAlso e.OldValue IsNot Nothing AndAlso e.OldValue <> e.NewValue Then
            dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [总账科目] = '" & e.OldValue & "'And [明细科目] = '" & e.OldValue & "'", "[_SortKey] Desc")
            If dr Is Nothing Then
                dr = e.DataTable.Find("[总账科目] = '" & e.OldValue & "'", "[_SortKey]")
                If dr IsNot Nothing Then
                    dr("余额") = dr("借方") - dr("贷方")
                End If
            End If
            If dr IsNot Nothing Then
                drs = e.DataTable.Select("[_SortKey] >= " & dr("_SortKey") & " And [总账科目] = '" & dr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "'", "[_SortKey]")
                For i As Integer = 1 To drs.Count - 1
                    drs(i)("余额") = drs(i-1)("余额") + drs(i)("借方") - drs(i)("贷方")
                Next
            End If
        End If
End Select

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/22 16:42:00 [显示全部帖子]

把期初的余额都清零了

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/22 18:03:00 [显示全部帖子]

还是不行

Select Case e.DataCol.Name
    Case "总账科目","明细科目","借方","贷方"
        Dim dr As DataRow
        Dim mr As DataRow = e.DataRow
        Dim drs As List(of DataRow)
        'dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [总账科目] = '" & mr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "'", "[_SortKey] Desc")
        dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [总账科目] = '" & mr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "' and 摘要<>'期初余额'", "[_SortKey] Desc")
        If dr Is Nothing Then
            mr("余额") = mr("借方") - mr("贷方")
            dr = mr
        End If
        drs = e.DataTable.Select("[_SortKey] >= " & dr("_SortKey") & " And [总账科目] = '" & dr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "'and 摘要<>'期初余额'", "[_SortKey]")
        For i As Integer = 1 To drs.Count - 1
            drs(i)("余额") = drs(i-1)("余额") + drs(i)("借方") - drs(i)("贷方")
        Next
        If e.DataCol.Name = "总账科目" AndAlso e.OldValue IsNot Nothing AndAlso e.OldValue <> e.NewValue Then
            dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [总账科目] = '" & e.OldValue & "'And [明细科目] = '" & e.OldValue & "'and 摘要<>'期初余额'", "[_SortKey] Desc")
            If dr Is Nothing Then
                dr = e.DataTable.Find("[总账科目] = '" & e.OldValue & "'And [明细科目] = '" & e.OldValue & "'and 摘要<>'期初余额'",  "[_SortKey]")
                If dr IsNot Nothing Then
                    dr("余额") = dr("借方") - dr("贷方")
                End If
            End If
            If dr IsNot Nothing Then
                drs = e.DataTable.Select("[_SortKey] >= " & dr("_SortKey") & " And [总账科目] = '" & dr("总账科目") & "'And [明细科目] = '" & mr("明细科目") & "', And 摘要<>'期初余额'", "[_SortKey]")
                For i As Integer = 1 To drs.Count - 1
                    drs(i)("余额") = drs(i-1)("余额") + drs(i)("借方") - drs(i)("贷方")
                Next
            End If
        End If
End Select

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/23 11:30:00 [显示全部帖子]

能贴出代码吗?我的版本不够。谢谢。

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/23 16:52:00 [显示全部帖子]

对于没有明细科目的行计算出错,代码如何修改?

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/23 17:11:00 [显示全部帖子]

谢了

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/24 12:54:00 [显示全部帖子]

9楼的代码余额计算还是不对。是这样的,明细账表是从其它表导入的,已经不再可编辑,只想通过筛选成为明细账的版式。
数据是批量导入的,不是一行一行增加的。
[此贴子已经被作者于2023/12/24 14:19:54编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/24 22:21:00 [显示全部帖子]

整个表的数据都是从其它表导入的
余额计算计算错误。
就只有明细账一张表数据已经导入,不再编辑,通过科目筛选,成为流水账版式。

图片点击可在新窗口打开查看此主题相关图片如下:snap1.jpg
图片点击可在新窗口打开查看

[此贴子已经被作者于2023/12/24 22:21:33编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
实话实说
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2649 积分:19390 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2023/12/25 10:13:00 [显示全部帖子]

16楼图就是重置列后的结果

 回到顶部
总数 16 1 2 下一页