簡體   English   中英

將數據幀寫入 R 中的多個 csv

[英]Write data frame to multiple csv's in R

我有以下數據框,其中包含有關不同狀態的信息。

long=c(-106.61291,-106.61291,-106.61291,-81.97224,-81.97224,-81.97224,-84.4277,-84.4277,-84.4277)
lat=c(35.04333,35.04333,35.04333,33.37378,33.37378,33.37378,33.64073,33.64073,33.64073)
city=c("Albuquerque","Albuquerque","Albuquerque","Augusta","Augusta","Augusta","Atlanta","Atlanta","Atlanta")
date=c("2017-08-22","2017-08-23","2017-09-24","2017-09-28","2017-10-24","2017-09-22","2017-11-12","2017-010-14","2017-09-03")
value=c(12,10.8,18.3,12.4,43,21,12,32.1,14)

df<-data.frame(long,lat,city,date,value)

問題:我想在單獨的 csv 中寫入每個城市信息。 每個 csv 應該如下所示。 最終輸出:

Albuquerque.csv
       long      lat        city       date value
1 -106.6129 35.04333 Albuquerque 2017-08-22  12.0
2 -106.6129 35.04333 Albuquerque 2017-08-23  10.8
3 -106.6129 35.04333 Albuquerque 2017-09-24  18.3

Augusta.csv
      long      lat    city       date value
1 -81.97224 33.37378 Augusta 2017-09-28  12.4
2 -81.97224 33.37378 Augusta 2017-10-24  43.0
3 -81.97224 33.37378 Augusta 2017-09-22  21.0

Atlanta.csv
      long      lat    city        date value
1 -84.4277 33.64073 Atlanta  2017-11-12  12.0
2 -84.4277 33.64073 Atlanta 2017-010-14  32.1
3 -84.4277 33.64073 Atlanta  2017-09-03  14.0

提前致謝!

# Split dataframe by city
split_df <- split(df, list(df$city))

# Write out separate CSV for each city
for (city in names(split_df)) {
    write.csv(split_df[[city]], paste0(city, ".csv"))
}
long=c(-106.61291,-106.61291,-106.61291,-81.97224,-81.97224,-81.97224,-84.4277,-84.4277,-84.4277)
lat=c(35.04333,35.04333,35.04333,33.37378,33.37378,33.37378,33.64073,33.64073,33.64073)  
city=c("Albuquerque","Albuquerque","Albuquerque","Augusta","Augusta","Augusta","Atlanta","Atlanta","Atlanta")
date=c("2017-08-22","2017-08-23","2017-09-24","2017-09-28","2017-10-24","2017-09-22","2017-11-12","2017-010-14","2017-09-03")
value=c(12,10.8,18.3,12.4,43,21,12,32.1,14)

df<-data.frame(long,lat,city,date,value)

dflist <- split(df , f = df$city)

sapply(names(dflist), 
 function (x) write.csv(dflist[[x]], file=paste(x, "csv", sep=".") )   )

有幾種不同的方法可以做到這一點,但是同時為所有城市執行此操作的一種非常快速的方法是利用基礎 R 中的apply函數系列 - 特別是lapply

long=c(-106.61291,-106.61291,-106.61291,-81.97224,-81.97224,-81.97224,-84.4277,-84.4277,-84.4277)
lat=c(35.04333,35.04333,35.04333,33.37378,33.37378,33.37378,33.64073,33.64073,33.64073)
city=c("Albuquerque","Albuquerque","Albuquerque","Augusta","Augusta","Augusta","Atlanta","Atlanta","Atlanta")
date=c("2017-08-22","2017-08-23","2017-09-24","2017-09-28","2017-10-24","2017-09-22","2017-11-12","2017-010-14","2017-09-03")
value=c(12,10.8,18.3,12.4,43,21,12,32.1,14)

df<-data.frame(long,lat,city,date,value)

# create a convenience function to split your data and export to csv
split_into_csv <- function(x) {
tmp <- df[df$city == x,]
write.csv(tmp, file = paste0(x,".csv"))}

# Apply split_into_csv over elements of list with lapply
lapply(levels(df$city), split_into_csv)
# Check output in director
dir()
[1] "Albuquerque.csv" "Atlanta.csv"     "Augusta.csv"  

您可以使用基本 R 或 dplyr 包來執行此操作。

dplyr方式:

dplyr::filter(df, city == 'Albuquerque') %>% write.csv(file = 'Albuquerque.csv', row.names = FALSE)
dplyr::filter(df, city == 'Augusta') %>% write.csv(file = 'Augusta.csv', row.names = FALSE)
dplyr::filter(df, city == 'Atlanta') %>% write.csv(file = 'Atlanta.csv', row.names = FALSE)

基礎R:

write.csv(df[df$city == 'Albuquerque', ], file = 'Albuquerque.csv', row.names = FALSE)
write.csv(df[df$city == 'Augusta', ], file = 'Augusta.csv', row.names = FALSE)
write.csv(df[df$city == 'Atlanta', ], file = 'Atlanta.csv', row.names = FALSE)

如果您開始獲得更多城市,則可以使用 for 循環。

for (city in c('Albuquerque', 'Augusta', 'Atlanta')) {
  write.csv(df[df$city == city, ], file = paste0(city, '.csv'))
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM