Я с трудом пытаюсь создать функцию с циклом for, которая берет столбцы в фрейме данных и создает разные графики на основе имени столбца. Я прочитал несколько разных связанных вопросов по SO, для пример,
1 : Создание функции для использования циклов с ggplot2 [2]: Зацикливание переменных в ggplot
но пока у меня ничего не получалось.
Пример данных:
philly_df_new <- structure(list(DATE = structure(c(14610, 14611, 14612, 14613,
14614, 14615, 14616, 14617, 14618, 14619, 14620, 14621, 14622,
14623, 14624, 14625, 14626, 14627, 14628, 14629), class = "Date"),
HOURLYDewPointTempC = c(0, -8.9, -15, -12.2, -11.7, -10.6,
-8.3, -4.4, -12.2, -17.2, -12.8, -6.1, -10.6, -7.8, -5.6,
-2.2, 0.6, 3.9, 0.6, -3.3), HOURLYSeaLevelPressure = c(30,
29.79, 29.78, 29.76, 29.81, 29.78, 29.89, 29.87, 29.98, 30.25,
30.27, 30.13, 30.22, 30.23, 30.21, 30.23, 30.14, 29.49, 29.95,
29.92), DAILYDeptFromNormalAverageTemp = c(-1.7, 2.4, -6.4,
-10.3, -6.2, -5.1, -1, -1, -5.9, -10.8, -11.8, -9.7, -3.7,
-1.7, -1.6, 4.4, 4.4, 6.4, 8.4, 4.3)), .Names = c("DATE",
"HOURLYDewPointTempC", "HOURLYSeaLevelPressure", "DAILYDeptFromNormalAverageTemp"
), row.names = c(NA, -20L), class = c("tbl_df", "tbl", "data.frame"
))
Различные коды, которые я пробовал:
Plot_Graph<-function(x,na.rm=T){
nm=names(x)
for (i in seq_along(nm)) {
print(ggplot(x,aes_string(x="DATE",y=i) +
geom_point()))
}
}
Plot_Graph(philly_df_new)
colNames <- names(philly_df_new)[2:4]
for(i in seq_along(colNames)){
plt <- ggplot(philly_df_new, aes_string(x="DATE", y = i)) +
geom_point(color="#B20000", size=3, alpha=0.5,na.rm = T)
print(plt)
}
Когда я запускаю первую функцию, я получаю это сообщение об ошибке
Error: Mapping should be created with
АЕС () or
aes_ (). Когда я запускаю вторую функцию, я получаю график с одним и тем же графиком снова и снова с горизонтальной линией. Я попробовал больше способов, чем это, но для минимальных целей я покажу эти два. Я хочу создать график временных рядов для каждого столбца следующим образом:
![enter image description here](https://i.stack.imgur.com/ijkm4.png)