有一种使用的一种方式format的日期对象上的功能,特别是类的一个对象POSIXlt,POSIXct或者Date,与该格式%Y, %m, %d使得前导零从每个那些3个字段的剥离?
例如,我想format(as.Date("1998-09-02"), "%Y, %m, %d")回来1998, 9, 2而不是1998, 09, 02.
G. *_*eck 11
只需删除末尾的前导零:
> gsub(" 0", " ", format(as.Date("1998-09-02"), "%Y, %m, %d"))
[1] "1998, 9, 2"
使用%e获取前导空格而不是前导零.
我通过使用{lubridate} 包的year(),month()和day()函数发现了一种解决方法。在 的帮助下,很容易做到以下几点:glue::glue()
library(lubridate)
#> 
#> Attaching package: 'lubridate'
#> The following objects are masked from 'package:base':
#> 
#>     date, intersect, setdiff, union
library(glue)
dt <- "1998-09-02"
glue("{year(dt)}, {month(dt)}, {day(dt)}")
#> 1998, 9, 2
由reprex 包( v2.0.0 )于 2021 年 4 月 19 日创建
如果使用 {tidyverse}(@banbh 建议),则str_glue()可以使用:
library(tidyverse)
library(lubridate)
#> 
#> Attaching package: 'lubridate'
#> The following objects are masked from 'package:base':
#> 
#>     date, intersect, setdiff, union
dt <- "1998-09-02"
str_glue("{year(dt)}, {month(dt)}, {day(dt)}")
#> 1998, 9, 2
由reprex 包( v2.0.0 )于 2021 年 4 月 19 日创建
小智 9
您可以通过对strftime格式字符串进行简单更改来完成此操作。但是,这取决于您的平台(Unix 或 Windows)。
在-要从中删除前导零的每个术语之前插入一个减号 ( ):
format(as.Date("2020-06-02"), "%Y, %-m, %-d")
[1] "2020, 6, 2"
#在每个所需术语之前插入一个井号 ( ):
format(as.Date("2020-06-02"), "%Y, %#m, %#d")
[1] "2020, 6, 2"
| 归档时间: | 
 | 
| 查看次数: | 6577 次 | 
| 最近记录: |