gpt4 book ai didi

python - Google Bigquery 的 TIMESTAMP 的 python 数据类型是什么?

转载 作者:太空宇宙 更新时间:2023-11-04 07:54:58 26 4
gpt4 key购买 nike

我正在使用此处找到的 google-cloud-python 库将数据加载到 Google 的 BigQuery 中:

http://google-cloud-python.readthedocs.io/en/latest/index.html

其中一部分涉及检查我正在导入的数据的数据类型,以确保它们与目标表的架构中的数据类型相匹配。为此,我将 python 对象类型转换为 GBQ 等效类型:

import datetime 

def convert_type_to_bigquery(object_type):
if isinstance(object_type, str):
return 'STRING'
elif isinstance(object_type, bytes):
return 'BYTES'
elif isinstance(object_type, int):
return 'INTEGER'
elif isinstance(object_type, float):
return 'FLOAT'
elif isinstance(object_type, bool):
return 'BOOLEAN'
elif isinstance(object_type, datetime.date):
return 'DATE'
elif isinstance(object_type, datetime.time):
return 'TIME'
elif isinstance(object_type, datetime.datetime):
return 'DATETIME'
elif isinstance(object_type, ???):
return 'TIMESTAMP'
else:
return None

除了 TIMESTAMP 类型,我可以找到所有的等价物。我可以在 isinstance() 中使用等效项吗?

最佳答案

您可以使用 TIMESTAMP 对象执行 print(type(object_type)) 以确保,但是,根据此 github page , 它看起来只是 datetime.datetime:

...
Date = datetime.date
Time = datetime.time
Timestamp = datetime.datetime
...

我必须说,我想添加答案的主要原因是指出 ìsinstance(...) 的常见错误。这是行不通的,因为 boolint 的一个实例:

elif isinstance(object_type, int):
return 'INTEGER'
elif isinstance(object_type, float):
return 'FLOAT'
elif isinstance(object_type, bool):
return 'BOOLEAN'

看这个例子:

>>> isinstance(True, int)
True

您需要使用 elif type(object_type) is int: 或首先检查 bool

关于python - Google Bigquery 的 TIMESTAMP 的 python 数据类型是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50118404/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com