Countif Statement Showing Incorrect Value

Ark68

Well-known Member
Joined
Mar 23, 2004
Messages
4,650
Office Version
  1. 365
  2. 2016
Platform
  1. Windows
Rich (BB code):
           With ws_data    
                .Range("J:J").Clear
                For t = 2 To nwb_LastRow
                    rn_1 = .Cells(t, 3)
                    temp_fac = .Range("H" & t) & .Range("I" & t)
                    If Application.WorksheetFunction.CountIf(ws_rd.Range("A:A"), rn_1) = 0 Then
                        MsgBox "Rental does not exist in the database." & Chr(13) & "You were given lots of notice about processing missed rental information." & Chr(13) & "Now you're paying the price. Process terminated.", vbCritical, "CRITICAL ERROR : Missing Rental Data"
                        Exit Sub
                    End If
           End With

rn_1 = 84570
This value is found in column A of worksheet ws_rd at row 211.

Is anyone able to suggest why the countif statement (in blue) is failing? It proceeds through the code as though the value doesn't exist (countif = 0)

ws_rd is recognizing the correct worksheet.

Thank you in advance!
 
Last edited:

Excel Facts

Enter current date or time
Ctrl+: enters current time. Ctrl+; enters current date. Use Ctrl+: Ctrl+; Enter for current date & time.
Hi Dante Amor, thanks for stepping up!

I always struggle with that possibility?. If I go to the data worksheet, and use =isnumber(and select one of the values in column 3), it returns TRUE. I assume it means the contents are numeric and not text.

Anyone?
 
Upvote 0
I would have to review it with your data.

You could upload a copy of your file to a free site such www.dropbox.com. Once you do that, mark it for 'Sharing' and you will be given a link to the file that you can post here. If the workbook contains confidential information, you could replace it with generic data.
 
Upvote 0
And the macro?

The file does not have the macro, I need to check what each of the variables contains during the execution.
 
Upvote 0
Oh, that may not be very easy to provide unfortunately. Its part of a very large vba project depending on several workbooks and filled with network paths and userforms. You would be frustrated with all the errors as you dodge all that stuff just to get to here.

But thank you for trying Dante.

It shouldn't be overly complicated ... I personally think its a comparison of unlike data types but I have no way of proving.
Code:
         With ws_data   
             For t = 2 To nwb_LastRow
                    rn_1 = .Cells(t, 3)
                    temp_fac = .Range("H" & t) & .Range("I" & t)
                    If Application.WorksheetFunction.CountIf(ws_rd.Range("A:A"), rn_1) = 0 Then
                        MsgBox "Rental does not exist in the database." & Chr(13) & "You were given lots of notice about processing missed rental information." & Chr(13) & "Now you're paying the price. Process terminated.", vbCritical, "CRITICAL ERROR : Missing Rental Data"
                        Exit Sub
                    End If
                    .Range("A" & t) = format(.Range("B" & t), "00000") & format(t - 1, "000")
                    .Range("C1") = "CONTRACT_"
                    .Range("D" & t) = Application.WorksheetFunction.VLookup(rn_1, ws_rd.Range("A:BJ"), 2, False)    'ammendment
                    .Range("E" & t) = Application.WorksheetFunction.VLookup(rn_1, ws_rd.Range("A:BJ"), 3, False)    'activity type
                    .Range("F" & t) = Application.WorksheetFunction.VLookup(rn_1, ws_rd.Range("A:BJ"), 4, False)    'event
                    .Range("G" & t) = Application.WorksheetFunction.VLookup(rn_1, ws_rd.Range("A:BJ"), 11, False)    'customer name
                    .Range("J" & t) = Application.WorksheetFunction.VLookup(temp_fac, ws_fac1.Range("A:I"), 3, False) 'station
                    .Range("K" & t) = Application.WorksheetFunction.VLookup(temp_fac, ws_fac1.Range("A:I"), 4, False) 'type 1 (field, diamond etc)
                    .Range("L" & t) = Application.WorksheetFunction.VLookup(temp_fac, ws_fac1.Range("A:I"), 5, False) 'unit
                    .Range("V" & t) = 0
                    .Range("Y" & t) = .Range("U" & t)
                    .Range("BJ" & t) = Application.WorksheetFunction.VLookup(rn_1, ws_rd.Range("A:BJ"), 12, False)   'customer number
                Next t
         End With

ws_data holds the data, column C has the value I'm counting
rn_1 = 84330 ... checked at the source (ws_data) to be a number using "isnumber"
ws_rd, the file I posted, is the reference data. The values in column A are numbers as verified by "isnumber"
the value of rn_1 is found at row 155 of ws_rd.
 
Last edited:
Upvote 0
But I do not get to the search.
This is on another sheet?

Code:
[COLOR=#333333]With ws_data[/COLOR]
 
Upvote 0
check
rn_1 = 84569
rn_1 = 84570
rn_1 = 84571

and works

But I do not know where you get this from:
Code:
rn_1 = .Cells(t, "C")
 
Upvote 0
Yes, ws_data is another sheet. rn_1 is gathered from there and cross referenced with data in the worksheet I sent you.

I don't see where I used that Dante, I'm sorry. I have something similar ...
Code:
rn_1 = .Cells(t,3)

This line is extracting the value to count from a loop in worksheet ws_data. The loop checks (runs a count of) all the values in row t column c against the data in column A of ws_rd. I need to do a countif for each rows in ws_data, hence the loop.
 
Last edited:
Upvote 0

Forum statistics

Threads
1,225,739
Messages
6,186,738
Members
453,369
Latest member
juliewar

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top