-
Notifications
You must be signed in to change notification settings - Fork 992
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
as.IDate error that can be fixed #4676
Comments
Thanks @arunsrinivasan , this is inherited from
|
I am aware that the issue is in require(data.table) # 1.13.1 from today
x <- c("2020-01-01", "")
y <- c("", "2020-01-01")
y[y %chin% ""] <- NA_character_
as.IDate(x)
# [1] "2020-01-01" NA
as.IDate(y)
# [1] NA "2020-01-01" |
isn't this something that should be fixed in base, though? that was my
point in attributing the issue to base
…On Fri, Aug 21, 2020, 1:59 PM Arun Srinivasan ***@***.***> wrote:
I am aware that the issue is in as.Date. I forgot to mention it in the
original post. I was thinking the fix could be as simple as replacing all
"" with NA *before* passing it on to as.Date() method.
require(data.table) # 1.13.1 from todayx <- c("2020-01-01", "")y <- c("", "2020-01-01")y[y %chin% ""] <- NA_character_
as.IDate(x)# [1] "2020-01-01" NA
as.IDate(y)# [1] NA "2020-01-01"
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#4676 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AB2BA5OWDKRUVCIQDXK2WVLSB2YZ3ANCNFSM4QDBXBKQ>
.
|
That was my feeling too when I saw Arun's very clever "fudge". Drop in |
Why not? But I won't be using the recent version of R anytime soon for work. But I would be using a more recent data.table version sooner. So I'd suggest a/this workaround fix until R fixes this. |
BTW if the fix were to go into base R, they just need to add # this logic just needs to account for `""`: is.na(xx) ==> xx %in% c(NA_character_, "")
charToDate <- function(x) {
xx <- x[1L]
if (is.na(xx)) {
j <- 1L
while (is.na(xx) && (j <- j + 1L) <= length(x)) xx <- x[j]
if (is.na(xx))
f <- "%Y-%m-%d"
}
.... |
In any case we should raise the issue on Bugzilla. If base would change, we
need to be consistent with that. If they won't change, we can make our own
fix.
…On Fri, Aug 21, 2020, 3:37 PM Arun Srinivasan ***@***.***> wrote:
BTW if the fix were to go into base R, they just need to add "" to the
charToDate internal function in as.Date.character. Here's the relevant
part:
# this logic just needs to account for `""`charToDate <- function(x) {
xx <- x[1L]
if (is.na(xx)) {
j <- 1L
while (is.na(xx) && (j <- j + 1L) <= length(x)) xx <- x[j]
if (is.na(xx))
f <- "%Y-%m-%d"
}
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#4676 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AB2BA5JT6BU4FEGAYMVSVDLSB3EIPANCNFSM4QDBXBKQ>
.
|
I disagree. We should issue a fix while filing an issue there. Like I said, it takes time to get things into base R and people don't always use the most recent version of R, if you use in production. I'm all up for filing an issue there, but I'd like the issue taken care of in data.table nonetheless. |
I agree with you about it being easier/more common to update What I'm trying to prevent is setting ourselves up for a breaking change in a later release: T0: we submit an issue to Bugzilla & merge our own solution in So I think we should at least file the issue first & see if R core has any opinion. If not we just merge & move on. |
I have submitted a bug to R: https://bugs.r-project.org/bugzilla/show_bug.cgi?id=17909 Note the simpler fix:
|
Sorry but I'm having a hard time making sense of this. There are only two possible scenarios I can think of.
It has to be equal to the output of |
I've fixed the bug in R now (svn rev 79119 for 'R-devel' -- to be ported to "R 4.0.2 patched" in a few days ("almost surely"). |
R fixed this in 4.0.3 released on October 10. Should this be closed as is or should Michael's PR be merged first? |
would be nice to have something that works on our dependency ( R >= 3.1.0 )
…On Thu, Feb 4, 2021, 3:20 PM Cole Miller ***@***.***> wrote:
R fixed this in 4.0.3 released on October 10. Should this be closed as is
or should Michael's PR be merged first?
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#4676 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AB2BA5L4AXZAT7MG3GGIHLLS5MTTZANCNFSM4QDBXBKQ>
.
|
The text was updated successfully, but these errors were encountered: