VBA Dynamic Array converts text to numbers?

magemaester

New Member
Joined
Dec 17, 2017
Messages
10
Hi forum,


I have this piece of code which creates a dynamic array, redims it, then assigns a range of cells on a worksheet into it. The data that I populate into the array are ID's of people, that are formatted as TEXT with leading 0's. (e.g. "000123123", "000111223", "000199382".....)

Code:
[COLOR=#006400]'Creates array[/COLOR]
Dim Array() as Variant
ReDim Array (1 to 1000, 1)

[COLOR=#006400]'Populates array with TEXT from Column A[/COLOR]
Array = Range("A1:A1000").Value

[COLOR=#006400]'Pastes data from array into Column B[/COLOR]
Range("B1:B1000").Value = Array

However, when the values are pasted into Column B, all the leading "0"s disappear and the output is formatted as numbers. Does anyone know why that is happening/solution?

Many thanks.
 

Excel Facts

Fastest way to copy a worksheet?
Hold down the Ctrl key while dragging tab for Sheet1 to the right. Excel will make a copy of the worksheet.
Excel works hard to convert anything resembling a number to a number. Try it like this:
Code:
Sub ArrToB()
Dim Arr As Variant
Arr = Range("A1:A1000").Value
With Range("B1:B1000")
    .NumberFormat = "000######"
    .Value = Arr
End With
End Sub
BTW notice I used Arr as my variant not Array. The latter is the name of a VBA function and is likely to get you into trouble if used for anything else.
 
Upvote 0
.NumberFormat = "000######"
Why did you use that number format instead of "000000000"? The reason I ask is, with your format, if the number in the cell less than 6 digits long, that number would be prefixed with only three zeroes. For example, if the number were 123, you format would produce 000123 whereas I would expect the OP would want 000000123.
 
Upvote 0
Since your original data is Text, why not have your new data in the same format? A couple of ways ..
a) Pre-format column B as Text and your original code will work (after you fix the variable name 'Array' as mentioned by JoeMo), or
b) Use code like JoMoe's but have the code apply Text format instead of a Number format. That would preserve the original IDs no matter how many characters or leading zeroes it has.

So the last bit of the code would be
Code:
With Range("B1:B1000")
  .NumberFormat = "@"
  .Value = Arr
End With


BTW, there is no need for the ReDim in your code. When you read a range into the array, that redimensioning will happen automatically.
 
Last edited:
Upvote 0
Why did you use that number format instead of "000000000"? The reason I ask is, with your format, if the number in the cell less than 6 digits long, that number would be prefixed with only three zeroes. For example, if the number were 123, you format would produce 000123 whereas I would expect the OP would want 000000123.
I assumed all data would have the same format as the OP's examples. But, I think Peter has offered a better solution in post #4 .
 
Upvote 0

Forum statistics

Threads
1,225,749
Messages
6,186,802
Members
453,373
Latest member
Ereha

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