¦p¦ó§ïµ½³o¬qµ{¦¡¡AÅý°õ¦æ®Ä²v´£¤É¡H
| ©«¤l712 ¥DÃD281 ºëµØ0 ¿n¤À1019 ÂI¦W0  §@·~¨t²ÎWindows 10 ³nÅ骩¥»Office 2019 ¾\ŪÅv50 ©Ê§O¨k µù¥U®É¶¡2011-6-30 ³Ì«áµn¿ý2025-5-22 
 | 
 ¦p¦ó§ïµ½³o¬qµ{¦¡¡AÅý°õ¦æ®Ä²v´£¤É¡H
| ¥H¤W¬O¬Y¦ì¦Ñ®v¼¶¼g¡A¦³ÂI§Ñ¤F¬O½Ö(¥¢Â§¤F)¡A쥻³£¥ÎXPªºExcel°õ¦æ¡A®Ä²v³£ÁÙOK¡A½Æ»s¥N½XSub test()
'¦~«×¤ÀªR¡A¶}¾P«e3¦W
    Application.ScreenUpdating = False
    W = [W]
    r = [A1].CurrentRegion.Rows.Count
    Range("B7:M" & r).ClearContents
    Range("B2:M3").ClearContents
    myyear = [A1].Value
    For c = 2 To 13
        mymonth = myyear & "/" & Trim(Cells(1, c).Value)
        income = 0
        expense = 0
        pay = 0
        v = 11
        With Sheets("DataCopy")
            er = .[A100000].End(3).Row
            For r = 2 To er
                If myyear & "/" & Format(.Cells(r, 1).Value, "m¤ë¥÷") = mymonth Then
                    money = Val(.Cells(r, 3).Value)
                    Select Case .Cells(r, 2).Value
                        Case "¦¬¤J": income = income + money
                        Case "¤ä¥X": expense = expense + money
                        Case "¤À´Á¥I´Ú": expense = expense + money: pay = pay + 1
                    End Select
                    myitem = .Cells(r, 4).Value
                    If .Cells(r, 2).Value <> "¦¬¤J" Then
                        Set cell = Columns(c + 1).Find(myitem)
                        If Not cell Is Nothing Then
                            cell.Offset(, -1).Value = cell.Offset(, -1).Value + money
                        Else
                            Cells(v, c).Value = money
                            Cells(v, c + 1).Value = .Cells(r, 4).Value
                            v = v + 1
                        End If
                    End If
                End If
            Next r
            If Cells(11, c) <> "" Then
                Set rng = Range(Cells(11, c), Cells(v - 1, c + 1))
                rng.Sort key1:=Cells(11, c), order1:=xlDescending
                X = 0
                v = 11
                Do Until Cells(v, c).Value = ""
                    If InStr(W, Cells(v, c + 1)) = 0 Then
                        If X < 3 Then
                            X = X + 1
                            Cells(X + 6, c).Value = X & ". " & Cells(v, c + 1).Value & " / " & Cells(v, c).Value & "¤¸"
                        End If
                    End If
                    Cells(v, c).Value = v - 10 & ". " & Cells(v, c + 1).Value & " / " & Cells(v, c).Value & "¤¸"
                    Cells(v, c + 1).Value = ""
                    v = v + 1
                Loop
            End If
        End With
        Cells(2, c).Value = IIf(income <> 0, income, "")
        Cells(3, c).Value = IIf(expense <> 0, expense, "")
        Cells(10, c).Value = pay
    Next c
    Application.ScreenUpdating = True
'¦Û°Ê´«¦æ
    Rows("7:100000").EntireRow.AutoFit
    Application.ScreenUpdating = True
End Sub
´«¦¨2010«á¡A°õ¦æ¥H«á·|Åܱo«D±`«D±`ªººC¡A¤£ª¾¹D¦³¨S¦³¿ìªk§ïµ½¡AÁÂÁ¡I
 | 
 | 
|  | 
|  |  | 
|  |  |