當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


R tibble add_row 將行添加到 DataFrame


這是向現有 DataFrame 添加一行或多行數據的便捷方法。請參閱tribble() 了解創建完整 DataFrame row-by-row 的簡單方法。使用tibble_row()確保新數據隻有一行。

add_case()add_row() 的別名。

用法

add_row(.data, ..., .before = NULL, .after = NULL)

參數

.data

要附加到的 DataFrame 。

...

< dynamic-dots > Name-value 對,傳遞給 tibble() 。隻能為 .data 中已存在的列定義值,未設置的列將獲得 NA 值。

.before, .after

基於一的行索引在何處添加新行,默認值:最後一行之後。

也可以看看

其他補充:add_column()

例子

# add_row ---------------------------------
df <- tibble(x = 1:3, y = 3:1)

df %>% add_row(x = 4, y = 0)
#> # A tibble: 4 × 2
#>       x     y
#>   <dbl> <dbl>
#> 1     1     3
#> 2     2     2
#> 3     3     1
#> 4     4     0

# You can specify where to add the new rows
df %>% add_row(x = 4, y = 0, .before = 2)
#> # A tibble: 4 × 2
#>       x     y
#>   <dbl> <dbl>
#> 1     1     3
#> 2     4     0
#> 3     2     2
#> 4     3     1

# You can supply vectors, to add multiple rows (this isn't
# recommended because it's a bit hard to read)
df %>% add_row(x = 4:5, y = 0:-1)
#> # A tibble: 5 × 2
#>       x     y
#>   <int> <int>
#> 1     1     3
#> 2     2     2
#> 3     3     1
#> 4     4     0
#> 5     5    -1

# Use tibble_row() to add one row only
df %>% add_row(tibble_row(x = 4, y = 0))
#> # A tibble: 4 × 2
#>       x     y
#>   <dbl> <dbl>
#> 1     1     3
#> 2     2     2
#> 3     3     1
#> 4     4     0
try(df %>% add_row(tibble_row(x = 4:5, y = 0:-1)))
#> Error in tibble_quos(xs, .rows = 1, .name_repair = .name_repair, single_row = TRUE) : 
#>   All vectors must be size one, use `list()` to wrap.
#> ✖ Column `x` is of size 2.

# Absent variables get missing values
df %>% add_row(x = 4)
#> # A tibble: 4 × 2
#>       x     y
#>   <dbl> <int>
#> 1     1     3
#> 2     2     2
#> 3     3     1
#> 4     4    NA

# You can't create new variables
try(df %>% add_row(z = 10))
#> Error in add_row(., z = 10) : New rows can't add columns.
#> ✖ Can't find column `z` in `.data`.
源代碼:R/add.R

相關用法


注:本文由純淨天空篩選整理自Kirill Müller等大神的英文原創作品 Add rows to a data frame。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。