How to deal with a 50GB large csv file in r language?

后端 未结 2 508
滥情空心
滥情空心 2021-02-03 13:45

I am relatively new in the \"large data process\" in r here, hope to look for some advise about how to deal with 50 GB csv file. The current problem is following:

Table

相关标签:
2条回答
  • 2021-02-03 14:22

    This is too long for a comment.

    R -- in its basic configuration -- loads data into memory. Memory is cheap. 50 Gbytes still is not a typical configuration (and you would need more than that to load the data in and store it). If you are really good in R, you might be able to figure out another mechanism. If you have access to a cluster, you could use some parallel version of R or Spark.

    You could also load the data into a database. For the task at hand, a database is very well suited to the problem. R easily connects to almost any database. And, you might find a database very useful for what you want to do.

    Or, you could just process the text file in situ. Command line tools such as awk, grep, and perl are very suitable for this task. I would recommend this approach for a one-time effort. I would recommend a database if you want to keep the data around for analytic purposes.

    0 讨论(0)
  • 2021-02-03 14:26

    You can use R with SQLite behind the curtains with the sqldf package. You'd use the read.csv.sql function in the sqldf package and then you can query the data however you want to obtain the smaller data frame.

    The example from the docs:

    library(sqldf)
    
    iris2 <- read.csv.sql("iris.csv", 
        sql = "select * from file where Species = 'setosa' ")
    

    I've used this library on VERY large CSV files with good results.

    0 讨论(0)
提交回复
热议问题