我想在(R)脚本中使用fread
,该脚本将通过linux管道机制获取输入数据。以下内容是否有fread
模拟?
read.csv(file = 'stdin', ...)
我还将满足于以其他方式读取stdin
,然后使用fread
来解析它,因为我主要希望fread
的高级分隔符和标头逻辑能够这样做。
原来它很简单:
fread('file:///dev/stdin')
这是有效的,因为当前7个字符是"file://"或"http://"时,fread
实际上会创建一个临时文件,并使用download.file
将数据复制到那里,然后再使用fread
复制。
更新:从1.8.11版本开始,可以在fread
中使用shell命令,从而使另一种解决方案成为可能:
fread('cat /dev/stdin')
所有read.*
函数都在其引擎盖下使用"scan"。scan
是一个相当低的级别,但确实具有将数据行解析为不同类的能力。
> mat <- matrix(scan(), 4,4) # will paste in block of data
1: 0.5 0.1428571 0.25
4: 0.5 0.1428571 0.25
7: 0.5 0.1428571 0.25
10: 0.5 0.1428571 0.25
13: 0.5 0.1428571 0.25
16: 0.5
17: # Terminate with two <cr>'s
Read 16 items
> mat
[,1] [,2] [,3] [,4]
[1,] 0.5000000 0.1428571 0.2500000 0.5000000
[2,] 0.1428571 0.2500000 0.5000000 0.1428571
[3,] 0.2500000 0.5000000 0.1428571 0.2500000
[4,] 0.5000000 0.1428571 0.2500000 0.5000000
> lst <- scan(what=list(double(0), "a"))
1: 4 t
2: 6 h
3: 8 l
4: 8 8
5:
Read 4 records
> lst
[[1]]
[1] 4 6 8 8
[[2]]
[1] "t" "h" "l" "8"
您还应该查看?connections
页面。