overriding array size

  • Thread starter Thread starter Dave Cullen
  • Start date Start date
D

Dave Cullen

I have a program that reads a delimited text file and splits the input
string into string array elements:

Dim Data(41) as String

'read semicolon delimited fields into string array
Data = SrRead.ReadLine().Split(";".ToCharArray)

I expect up to 40 elements to be read. But if the input data string has
less than that and I try to access Data(40) I get a
System.IndexOutOfRange exception. I thought that declaring the array
size first would take care of that.

I know I can GetLength on the array and know how big it is. But is there
a way to statically set the array bounds so I don't need to know?

Thanks
 
Don't defind the number ahead of time. Let it find it for you when it reads
the first line.

Dim fieldValues As String()

'Open file and read first line to determine how many fields
'there are.
myReader = IO.File.OpenText(fileFullPath)
fieldValues = myReader.ReadLine().Split(seperator)
 
Dave Cullen said:
I have a program that reads a delimited text file and splits the input
string into string array elements:

Dim Data(41) as String

.... is semantically equivalent to 'Dim Data() As String = New String(41)
{}'.
'read semicolon delimited fields into string array
Data = SrRead.ReadLine().Split(";".ToCharArray)

'Split' returns a dimensioned and filled array object. Thus you do not need
to dimension the array at its declaration:

\\\
Dim Data() As String = SrRead.ReadLine.Split(...)
///
 
Dim MyArr As Array
Dim MyString Ss String
Dim i As Integer

' Build string
MyString = "What;Are;You;Doing"

' Put it into an array - spliting each element with delimiter
MyArr = Split(MyString, ";")

' Loop through array
For i = LBound(MyArr) to UBound(MyArr)
Dim MyRow as String = MyArr(i)
Next

The Grand Master
 
Dave said:
I have a program that reads a delimited text file and splits the input
string into string array elements:

Dim Data(41) as String

'read semicolon delimited fields into string array
Data = SrRead.ReadLine().Split(";".ToCharArray)

I expect up to 40 elements to be read. But if the input data string has
less than that and I try to access Data(40) I get a
System.IndexOutOfRange exception. I thought that declaring the array
size first would take care of that.

I know I can GetLength on the array and know how big it is. But is there
a way to statically set the array bounds so I don't need to know?

It's Kludgey in the extreme, but you could force the array size after
you've loaded it, as in :

Dim Data as String() _
= SrRead.ReadLine().Split(";"c)

ReDim Preserve Data(40)

I've yet to find a ".Net" equivalent of ReDim Preserve ...

HTH,
Phill W.
 
Thank you Phill, that works. The other solutions posted would require me
to test the size of the array before attempting to read each element
(tedious), or abort if the length was not what I expect.

With the ReDim Preserve I get to have a valid array of the size expected
(no crash & burn when I read element 40) and also have backward
compatibility with data files that have less than the expected number of
elements.

Thanks again
Dave
 
Back
Top