-
Notifications
You must be signed in to change notification settings - Fork 54
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
Use DataAPI.rownumber
#334
base: main
Are you sure you want to change the base?
Conversation
@@ -1,7 +1,7 @@ | |||
name = "Tables" | |||
uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" | |||
authors = ["quinnj <quinn.jacobd@gmail.com>"] | |||
version = "1.10.1" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also DataAPI.jl version requirement needs to be changed below.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ho yes I forgot this you're right. Done in aefedf6
Can you please add tests for all 5 types? |
Hoo, when making the tests I did realise I was completely misinterpreting the row argument, it was not an index, but the actual data of the row... That's why tests are so valuable ^^. So I don't think we can get the row number without adding it as a field of the rows structures for: There's two choices from here, either we add a field for the row index into these structures, or we don't define I made an example implementation of a row number in |
Let us wait for @quinnj to decide on this. My thinking is that:
so I would be OK to add it. The only downside could be that in some cases these objects could be generated from sources that do not have a proper row numbering. However, I am not sure if this is possible. @quinnj should know. |
Now using the newly proposed
DataAPI.rownumber
interface (JuliaData/DataAPI.jl#60). We add an implementation for:Tables.ColumnsRow
,Tables.DictRow
,Tables.IteratorRow
andTables.MatrixRow
.Note: a similar function (
getrow
) existed already forColumnsRow
andIteratorRow
. These functions were not removed as a precaution, but rather used for implementingDataAPI.rownumber
(i.e.rownumber(c::ColumnsRow) = getrow(c)
)The implementation for
Tables.Row
is justrownumber(x::Row) = rownumber(x.x)
. Maybe we should add a fallback or throw an explicit error if the row type does not implementrownumber
?