Excel VBA-引起错误类型不匹配的总和

问题描述 投票:0回答:1

我正在工作表中循环以求和“ C”和“ D”的金额。

每个选项卡的M列中的金额以及在N列中是贷方还是借方的金额,由字母C或D表示。

首先,我将字母C和D放在空白单元格上,并尝试将这两个数字相加。

我在sumif行出现类型不匹配错误,并且整个行都突出显示。

起初我以为可能是ws = Worksheets(I)引起了问题,所以我将它们换成了Worksheets(I),但仍然没有用。

Sub Sumiftabs()

Dim Filepath As String    
Dim UIGFile As Workbook    
Dim Column As String    
Dim Month As String    
Dim Year As Integer    
Dim I As Long    
Dim TY As Integer    
Dim TYLetter As String    
Dim T As Long
Dim TreatyYear As Long    
Dim WS_Count As Integer    
Dim ws As Worksheet


Application.ScreenUpdating = False

TreatyYear = Sheets("Control").Range("B7").Value

'On Error Resume Next

For T = TreatyYear To 16 Step -1    
TYLetter = WorksheetFunction.VLookup(T, Workbooks("Separate tabs.xlsm").Sheets("Control").Range("H:I"), 2, False)    
TY = Sheets("Control").Range("B7").Value    
Month = Sheets("Control").Range("B5").Value    
Year = Sheets("Control").Range("B4").Value    
Filepath = Sheets("Control").Range("B2").Value    

Set UIGFile = Workbooks.Open("K:\Ayoon\UIG\" & Year & "\" & Month & "\UIG_NSA_MonYear_TY" & T & ".xls")

WS_Count = UIGFile.Worksheets.Count

For I = WS_Count To 1 Step -1

Set ws = Worksheets(I)

'Direct Premium
UIGFile.Worksheets(I).Range("S4").Value = "C"    
UIGFile.Worksheets(I).Range("S5").Value = "D"    
UIGFile.Worksheets(I).Range("T4").Value = _
   Application.WorksheetFunction.SumIf(ws.Range("N:N"), ws.Range("S:S"), ws.Range("M:M"))

UIGFile.Worksheets(I).Range("T5").Value = _
   Application.WorksheetFunction.SumIf(ws.Range("N:N"), ws.Range("S:S"), ws.Range("M:M"))

Next I

UIGFile.Close savechanges:=True


Next T

Application.ScreenUpdating = True

End Sub
excel-vba
1个回答
0
投票

您的SUMIF看起来不正确。

例如,尝试以下方法:

UIGFile.Worksheets(I).Range("T4").Value = _
    Application.WorksheetFunction.SumIf(ws.Range("N:N"), "C", ws.Range("M:M"))
© www.soinside.com 2019 - 2024. All rights reserved.