readLines!

Syntax

readLines!(handle, holder, [offset=0], [length=1])

Arguments

handle is the handle of the file to read.

holder is the variable that saves the data that are imported into the system.

offset (optional) is the starting position of the holder to save the lines.

length (optional) is the number of lines to read.

Details

Read a number of lines from the handle and save them to holder starting from the given offset, and return the number of lines read.

The readLines function returns a string vector for every call. It takes a certain amount of time to create a string vector, so it saves time if we can reuse the same vector as the buffer when a function call repeats. readLines! is such a function that accepts the existing buffer as data holder. The 2 examples below read the same amount of data for 100 times. It is faster to use readLines! than readLines .

Examples

timer(100){
fin = file("test.txt")
do{ y=fin.readLines(1024) } while(y.size()==1024)
fin.close()
};
// Time elapsed: 79.511 ms

timer(100){
fin = file("test.txt")
y=array(STRING,1024)
do{ lines = fin.readLines!(y,0,1024) } while(lines==1024)
fin.close()
};
// Time elapsed: 56.034 ms