Re: [問題] 如何讀入多個CSV檔

作者: celestialgod (天)   2016-01-14 17:37:42
※ 引述《clansoda (小笨)》之銘言:
: 最近在Coursera上面自己學習R語言,可是礙於過去沒寫過程式也沒人能討論
: 因此問的問題很淺顯希望大家見諒
歡迎常來討論^^
: 我現在遇到一個老師給的習題,要我們讀入332個CSV檔案來寫出算平均數的
: Function,我目前是用list.file這個函數先將所有CSV檔案弄成一個list
: 那應該就會有一個list有332個vector,我想用for函數讀CSV檔
: 我寫成for (i in 1:length(kk)) {read.csv("D:/kk[[i]].csv")->item}
" " 裡面一定是字串,你裡面放變數,他也不會跑出來
要那樣做只能:
eval(parse(text = paste0("D:/", kk[[i]])))
但是我並不推薦用eval的作法 我在MATLAB板每次都會強調eval is evil!
所以下面示範一個比較好的方式做處理
: KK是list的名稱 這樣如果i為一她應該會讀list的第一項叫做001.csv的檔案
: 這是我自己的想法,可是拿去跑之後會顯示 Error in file(file, "rt") : cannot open the connection In addition: Warning
: message:
: In file(file, "rt") :
: cannot open file 'specdata/kktix[[i]]': No such file or directory
: 不知道版上有沒有大大可以糾正我的寫法跟觀念。
: [軟體熟悉度]:
: 請把以下不需要的部份刪除
: 新手(沒寫過程式,R 是我的第一次)
csv_files <- list.files()[grepl('\\.csv', list.files())] # 抓出.csv結尾的檔案
csv_tables <- vector('list', length(csv_files))
for (i in seq_along(csv_files))
csv_tables[[i]] <- read.csv(csv_files[[i]])
如果你的檔案不是在工作目錄可以這樣改:
files <- list.files('path/to/csv', full.names = TRUE)
csv_files <- files[grepl('\\.csv', files)]
作者: clansoda (小笨)   2016-01-14 18:46:00
想請問list不是比vector還算大一階嗎 為什麼mode可以是list 這樣的用意又在哪裡呢?感謝大大 我還有好幾個問題
作者: obarisk (OSWALT)   2016-01-14 19:15:00
其實不用eval啊,用paste0補路徑也可以
作者: clansoda (小笨)   2016-01-14 19:15:00
第一行 雖然我沒學過grepl但是自己摸幾次大概也看得懂在在寫什麼我寫到for (i in seq(csv_files) 那邊 我有加1:但是這個寫法是錯的 請問in seq_along就已經是代表1到該list的長度了嗎現在遇到的問題是print出來的結果確實是所有的CSV檔集合
作者: obarisk (OSWALT)   2016-01-14 19:17:00
代表把變數直接放到i
作者: clansoda (小笨)   2016-01-14 19:17:00
但是我想要合併成一個dataframe不知道該如何下手直接rbind好像不是正確的解
作者: obarisk (OSWALT)   2016-01-14 19:18:00
我回錯@@
作者: clickhere (It's time to go home.)   2016-01-15 09:25:00
is.vector(list()); is.list(vector())list是vector. 反之則否.

Links booklink

Contact Us: admin [ a t ] ucptt.com