Skip to content
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

fix: read_gbq supports extreme DATETIME values such as 0001-01-01 00:00:00 #444

Merged
merged 40 commits into from
Jan 5, 2022

Conversation

tswast
Copy link
Collaborator

@tswast tswast commented Dec 6, 2021

Thank you for opening a Pull Request! Before submitting your PR, there are a few things you can do to make sure it goes smoothly:

  • Make sure to open an issue as a bug/issue before writing your code! That way we can discuss the change, evaluate designs, and agree on the general idea
  • Ensure the tests and linter pass
  • Code coverage does not decrease (if any source code was changed)
  • Appropriate docs were updated (if necessary)

Fixes #365 🦕

@product-auto-label product-auto-label bot added the api: bigquery Issues related to the googleapis/python-bigquery-pandas API. label Dec 6, 2021
@tswast
Copy link
Collaborator Author

tswast commented Dec 7, 2021

I think we need to remove the datetime64[ns] values from the dtypes map, since they don't map to the full allowed range of values in BigQuery. Instead, do a post-processing step with a couple of fallbacks depending on out-of-bounds errors (assuming the user hasn't already manually overridden the dtypes).

fastavro
flake8
numpy==1.16.6
google-cloud-bigquery==1.11.1
google-cloud-bigquery==1.26.1
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Needed for date_as_object parameter

@tswast tswast marked this pull request as ready for review December 30, 2021 22:53
@tswast tswast requested a review from a team December 30, 2021 22:53
@tswast tswast requested a review from a team as a code owner December 30, 2021 22:53
"FLOAT": np.dtype(float),
"GEOMETRY": "object",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure how the changes here to non-datetime-related mappings relates to this PR.

If these changes are intentional, then the comment above seems to require a corresponding update to docs/reading.rst.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

object types were removed because it's the default anyway.

@@ -28,12 +28,13 @@
"pandas >=0.24.2",
"pyarrow >=3.0.0, <7.0dev",
"pydata-google-auth",
"google-api-core >=1.14.0",
"google-api-core >=1.21.0",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems unrelated, and unmotivated by anything in the changelog for that release.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Correct. Needed to update due to updating the minimum google-cloud-bigquery, though.

We do use google-api-core directly, so I think it makes sense to include here still.

google-api-core==1.14.0
google-auth==1.4.1
google-api-core==1.21.0
google-auth==1.18.0
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Doesn't match the minimum constraint in setup.py.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Updated setup.py. Needed this version due to updated google-api-core (via google-cloud-bigquery)

@tswast tswast requested review from tseaver and shollyman January 4, 2022 16:53
Copy link
Collaborator

@shollyman shollyman left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, though all this version checking feels mildly terrifying.


for field in schema_fields:
column = str(field["name"])
# This method doesn't modify ARRAY/REPEATED columns.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this imply a TODO for later, or is the nature of pandas such that arrays are just always an object that gets no special processing?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Potential TODO, but such a low priority I don't think it's worth calling out. Now that we have https://github.com/googleapis/python-db-dtypes-pandas we have more flexibility in terms of creating dtypes that are more efficient than Python object columns. Though in this case, I'm not sure we'd have any better of an approach than https://github.com/xhochy/fletcher

@tswast
Copy link
Collaborator Author

tswast commented Jan 5, 2022

LGTM, though all this version checking feels mildly terrifying.

Yeah, for sure... I'd very much like to give our pandas-gbq users as wide a set of versions as possible, though. Those folks are often stuck in (notebook) environments with some core dependencies locked.

@tswast tswast added the automerge Merge the pull request once unit tests and other checks pass. label Jan 5, 2022
@tswast tswast merged commit d120f8f into googleapis:main Jan 5, 2022
@gcf-merge-on-green gcf-merge-on-green bot removed the automerge Merge the pull request once unit tests and other checks pass. label Jan 5, 2022
@tswast tswast deleted the issue365-extreme-datetimes branch January 5, 2022 22:17
gcf-merge-on-green bot pushed a commit that referenced this pull request Jan 19, 2022
🤖 I have created a release *beep* *boop*
---


## [0.17.0](v0.16.0...v0.17.0) (2022-01-19)


### ⚠ BREAKING CHANGES

* use nullable Int64 and boolean dtypes if available (#445)

### Features

* accepts a table ID, which downloads the table without a query ([#443](#443)) ([bf0e863](bf0e863))
* use nullable Int64 and boolean dtypes if available ([#445](#445)) ([89078f8](89078f8))


### Bug Fixes

* `read_gbq` supports extreme DATETIME values such as `0001-01-01 00:00:00` ([#444](#444)) ([d120f8f](d120f8f))
* `to_gbq` allows strings for DATE and floats for NUMERIC with `api_method="load_parquet"` ([#423](#423)) ([2180836](2180836))
* allow extreme DATE values such as `datetime.date(1, 1, 1)` in `load_gbq` ([#442](#442)) ([e13abaf](e13abaf))
* avoid iteritems deprecation in pandas prerelease ([#469](#469)) ([7379cdc](7379cdc))
* use data project for destination in `to_gbq` ([#455](#455)) ([891a00c](891a00c))


### Miscellaneous Chores

* release 0.17.0 ([#470](#470)) ([29ac8c3](29ac8c3))

---
This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please).
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
api: bigquery Issues related to the googleapis/python-bigquery-pandas API.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Out of bounds nanosecond timestamp: 1-01-01 00:00:00
3 participants