Pandas 创建DataFrame提示:type object ‘object‘ has no attribute ‘dtype‘
2023-03-20 14:56:18 时间
pandas版本0.25.3
import pandas as pd
symbol_info_columns = ['1', '持仓方向', '持仓量', '持仓收益率', '持仓收益', '持仓均价', '当前价格', '最大杠杆'] # v3
symbol_config = {'BTC': 'BTC-USDT-210924', 'LTC': 'LTC-USDT-210924', 'EOS': 'EOS-USDT-210924', 'ETH': 'ETH-USDT-210924', 'XRP': 'XRP-USDT-210924', 'FIL': 'FIL-USDT-210924'}
symbol_info = pd.DataFrame()
# dates = pd.date_range('20190101', periods=6)
# num_df = pd.DataFrame(data=np.random.randn(6, 8), index=dates, columns=symbol_info_columns)
symbol_info = pd.DataFrame(index=symbol_config.keys(), columns=symbol_info_columns)
data为空,且dtype默认为空时
出现type object ‘object’ has no attribute 'dtype’告警
原因分析:
创建DataFrame时,data字段为空
会默认创建一个空字典作为data
def __init__(self, data=None, index=None, columns=None, dtype=None, copy=False):
if data is None:
data = {}
然后初始化字典
elif isinstance(data, dict):
mgr = init_dict(data, index, columns, dtype=dtype)
init_dict函数中:
columns非空,且dtype默认为None时,会赋值nan_dtype = object
if columns is not None:
if missing.any() and not is_integer_dtype(dtype):
if dtype is None or np.issubdtype(dtype, np.flexible):
# GH#1783
nan_dtype = object
该object下无dtype方法
可能是object引用错误
解决方案:
pandas(版本0.25.3)init_dict函数位于
D:Users。。。Anaconda3envsPython3.7Libsite-packagespandascoreinternalsconstruction.py
参考Python3.9环境中pandas(版本1.2.5)
同名函数(D:Users。。。Anaconda3envsPython3.7Libsite-packagespandascoreinternalsconstruction.py)写法
nan_dtype = np.dtype(object)
可见该问题应该是pandas(版本0.25.3)的bug
相关文章
- 盘点全球最热门十家大数据公司中国占据三席
- 四款有针对大数据的数据处理系统
- 备战双十一,大数据告诉你哪家快递公司最强?
- 重新认识数据可视化
- Hadoop何以快速成为最佳网络安全工具?
- 大数据架构面临技术集成的巨大障碍
- 从数据流动说开去,解读数据主权之争
- 数据模型多了,应该怎么管?
- 分布式系统,你真的了解吗?
- 大数据是市场“刚需”,也是“痛点”
- 大数据架构面临技术集成的巨大障碍
- 2017将至,大数据准备好了么?
- 窥探“大数据”全貌(技术篇、产业篇、企业转型篇)
- 如何成功完成数据中心升级而不停机?
- 最大限度提高数据中心效率的五种方法
- 企业关系网络分析,大数据时代淘金利器
- 四款有针对大数据的数据处理系统
- 数据中心机房建设标准规范
- “互联网+ 会员 + 大数据”俨然成为餐饮营销的黄金搭档
- 10家机构共同发起AI大数据加速器,这些投资人已经抓住了未来