[R] Pulling strings from a Flat file

David Winsemius dwinsemius at comcast.net
Wed Apr 6 04:59:47 CEST 2011


On Apr 5, 2011, at 7:48 PM, Kalicin, Sarah wrote:

> Hi,
>
> I have a flat file that contains a bunch of strings that look like  
> this. The file was originally in Unix and brought over into Windows:
>
> E123456E234567E345678E456789E567891E678910E. . . .
> Basically the string starts with E and is followed with 6 numbers.  
> One string=E123456, length=7 characters. This file contains 10,000's  
> of these strings. I want to separate them into one vector the length  
> of the number of strings in the flat file, where each string is it's  
> on unique value.
>
> cc<-c(7,7,7,7,7,7,7)
>> aa<- file("Master","r", raw=TRUE)
>> readChar(aa, cc, useBytes = FALSE)
> [1] "E123456"  "\nE23456" "7\nE3456" "78\nE456" "789\nE56"  
> "7891\nE6" "78910\nE"
>> close(aa)
>> unlink("Master")

 > txt <- "E123456E234567E345678E456789E567891E678910E"
# You could use readLines to bring in from the file
# and assign to a character vector for work in R.

 > gsub("(E[[:digit:]]{6})", "\\1\n", txt)
[1] "E123456\nE234567\nE345678\nE456789\nE567891\nE678910\nE"
# Seems to be "working" properly

 > ?scan

 > scan(textConnection(gsub("(E[[:digit:]]{6})", "\\1\n", txt)),  
what="character")
Read 7 items
[1] "E123456" "E234567" "E345678" "E456789" "E567891" "E678910" "E"

You might be able to use read.table or variants.

>
> The biggest issue is I am getting \n added into the string, which I  
> am not sure where it is coming from, and splices the strings. Any  
> suggestions on getting rid of the /n and create an infinite sequence  
> of 7's for the string length for the cc vector? Is there a better  
> way to do this?
>
> Sarah
>

David Winsemius, MD
West Hartford, CT



More information about the R-help mailing list