【发布时间】:2016-07-15 09:06:48
【问题描述】:
我有一个数据(大数据 125000 行,~20 MB),其中需要删除某些具有特定字符串的行,并且需要在读取过程中选择一些列。
首先,我发现grepl 函数无法正常工作,因为fread 将数据作为一列也显示在此question 中。
示例数据可以在here(遵循@akrun 建议)和这样的数据标题中找到
头(sum_data)
TRIAL : 1 3331 9091
TRIAL : 2 1384786531 278055555
2 0.10 0.000E+00 -0.0047 -0.0168 -0.9938 -0.0087 -0.0105 -0.9709 0.0035 0.0079 -0.9754 0.0081 0.0023 0.9997 -0.135324E-09 0.278754E-01
2 0.20 0.000E+00 -0.0121 0.0002 -0.9898 -0.0364 -0.0027 -0.9925 -0.0242 -0.0050 -0.9929 0.0029 -0.0023 0.9998 -0.133521E-09 0.425567E-01
2 0.30 0.000E+00 0.0193 -0.0068 -0.9884 0.0040 0.0139 -0.9782 -0.0158 0.0150 -0.9814 0.0054 -0.0008 0.9997 -0.134103E-09 0.255356E-01
2 0.40 0.000E+00 -0.0157 0.0183 -0.9879 -0.0315 -0.0311 -0.9908 -0.0314 -0.0160 -0.9929 0.0040 0.0010 0.9998 -0.134819E-09 0.257300E-01
2 0.50 0.000E+00 -0.0402 0.0300 -0.9832 -0.0093 0.0269 -0.9781 -0.0326 0.0247 -0.9802 0.0044 -0.0010 0.9997 -0.131515E-09 0.440350E-01
我尝试使用fread 读取数据并使用grepl 删除行;
files <-dir(pattern = "*sum.txt",full.names = FALSE)
library(data.table)
fread_files <- function(files){
sum_data_read <- fread(files,skip=2, sep="\t", ) #seperation is tab.
df_grep <- sum_vgm_read [!grepl("TRI",sum_vgm_read$V1),] # for removing the lines that contain "TRIAL" letter in V1 column. But so far there is no V1 column is recognized!!
df <- bind_rows(df_grep) #binding rows after removing
write.table(as.data.table(df),file = gsub("(.*)(\\..*)", "\\1_new\\2", files),row.names = FALSE,col.names = TRUE)
}
最后是lapply
lapply(files, fread_files)
当我执行此操作时,只会创建一行数据作为输出,这是正在发生的事情,但我不知道是什么。 提前感谢您的帮助!
【问题讨论】:
-
您是否只想读取文件、删除行和重写文件?或者你想要一个数据表或数据框来进行操作?
-
@Titolondon 感谢您的提问。我想写一个新文件而不是重写它们,并希望 data.frame 具有列名和更快的读取处理,因为我有很多文件。
-
您尝试过我的回答吗?它似乎做你想做的事: 1. 读取文件 2. 删除行 3. 在没有“试用”行的情况下写入一个新文件缺少什么?而且,顺便说一句,我在您的示例数据中看不到 colnames。你想要的colnames是什么?
标签: r data.table fread