前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Pandas 创建DataFrame提示:type object ‘object‘ has no attribute ‘dtype‘

Pandas 创建DataFrame提示:type object ‘object‘ has no attribute ‘dtype‘

作者头像
全栈程序员站长
发布2022-08-26 13:40:29
1.5K0
发布2022-08-26 13:40:29
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

pandas版本0.25.3

代码语言:javascript
复制
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

代码语言:javascript
复制
    def __init__(self, data=None, index=None, columns=None, dtype=None, copy=False):
        if data is None:
            data = { 
   }

然后初始化字典

代码语言:javascript
复制
elif isinstance(data, dict):
    mgr = init_dict(data, index, columns, dtype=dtype)

init_dict函数中: columns非空,且dtype默认为None时,会赋值nan_dtype = object

代码语言:javascript
复制
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\。。。\Anaconda3\envs\Python3.7\Lib\site-packages\pandas\core\internals\construction.py

参考Python3.9环境中pandas(版本1.2.5) 同名函数(D:\Users\。。。\Anaconda3\envs\Python3.7\Lib\site-packages\pandas\core\internals\construction.py)写法

代码语言:javascript
复制
nan_dtype = np.dtype(object)

可见该问题应该是pandas(版本0.25.3)的bug

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/144023.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档