在PyQt5中使用Pandas时的几个坑
最近在看Python GUI编程,在用到PyQt5+Pandas时遇到一些问题。这里把问题和解决方法整理一下。备查。
(好像不能上传附件,内容只好写在下面了。)
在PyQt5中使用Pandas时的几个坑
在PyQt5中使用Pandas时需要的模块库为:qtpandas,版本为1.0.4以上,才支持PyQt5。安装过程不说了,找各种方法安装吧。
安装完成后,为检测是否安装成功,运行qtpands提供的例子:BasicExample.py,过程中暴露出很多问题。
1. 无法从pandas.tslib中加载NaTType
报错模块:EditDialogs.py
模块位置:<安装目录>\Anaconda3\lib\site-packages\qtpandas-1.0.4-py3.7.egg\qtpandas\views
报错语句:from pandas.tslib import NaTType
修复方法:
从网上找到了一种方法,有效。修改报错语句为:from pandas._libs.lib import *
2. 'DataFrame' object has no attribute 'ix'
在解决上面的错误后,运行例子,并显示初始界面,但在加载数据的过程中报错。
错误信息:'DataFrame' object has no attribute 'ix'
报错模块:DataFrameModel.py
模块位置:<安装位置>\Anaconda3\lib\site-packages\qtpandas-1.0.4-py3.7.egg\qtpandas\models
报错语句:凡在对DataFrame的操作中使用了“.ix[row_index, column_index]”或类似操作的,多处。
修复方法:
猜测该错误的原因可以是qtpandas的Pandas新、旧版本之间不兼容,我使用的Pandas版本为1.0.1,已经不支持“ix”了。跟踪发现,此时row_index为整型数据,column_index为字符串数据,所以将所有使用“.ix”的地方修改为“.loc”,问题解决。
3. <class 'ValueError'>
上面问题解决后,继续运行例子,在向DataFrame添加新的列时,列名称填写“d”(应该可以任意),列的数据类型选择“datetime”类型,注意:没有填写默认值,然后在点击“OK”时,报错。
错误信息:Location based indexing can only have [integer, integer slice (START point is INCLUDED, END point is EXCLUDED), listlike of integers, boolean array] types (大意是:基于位置的索引只能有[integer,integer 切片(包括起点,不包括终点),listlike of integers,boolean array]类型)
报错模块:DataFrameModel.py
模块位置:<安装位置>\Anaconda3\lib\site-packages\qtpandas-1.0.4-py3.7.egg\qtpandas\models
报错语句:int(self._dataFrame.iloc[row, col])
修复方法:将出错的语句改为:int(self._dataFrame.loc[row, col]),即使用“loc”替换“iloc”
4. name 'NaTType' is not defined
第1个问题是import语句加载模块库时报错,这个错误则是在运行时报错。
错误信息:name 'NaTType' is not defined
报错模块:EditDialogs.py
模块位置:<安装位置>\Anaconda3\lib\site-packages\qtpandas-1.0.4-py3.7.egg\qtpandas\views
报错语句:if isinstance(defaultValue, NaTType):
修复方法:
问题的原因还是qtpandas的版本1.0.4与pandas的版本(1.0.1)不匹配造成的,具体原因是qtpandas使用的是0.2.0的pandas,而官方文档说明在pandas 0.2.0以后的版本,对于“NaTType”不再支持,应改为type(pandas.NaT)。按这个说法,将上面报错的语句修改为if isinstance(defaultValue, type(pandas.NaT)):,同时在该模块的顶部添加:import pandas。
5. 'DataFrame' object has no attribute 'set_value'
在解决上面的问题后,再运行例子,添加datetime类型的列正常(其他数据类型未测试),添加的列正确显示在界面的“表格”中,同时新添加的列的各行数据被赋予“2000-01-01”的默认值。
此时,双击新添加的列对应的值,“表格”中出现一个SpinBox,方便对日期进行调整。调整后,或不做任何调整,鼠标在其他地方单击,则报这个错误。
错误信息:'DataFrame' object has no attribute 'set_value'
报错模块:DataFrameModel.py
模块位置:\Anaconda3\lib\site-packages\qtpandas-1.0.4-py3.7.egg\qtpandas\models
报错语句:self._dataFrame.set_value(row, col, value)
修复方法:
原因是DataFram类中没有“set_value()”方法。
根据Stack Overflow网站介绍的方法,将出错的语句修改为:self._dataFrame.at[row, col] = value
运行不报错,且结果也正确。
总结
总的感觉是这个版本的qtpandas_1.0.4存在许多问题,而且几乎所有问题都是qtpandas与pandas版本不匹配造成的。不想一一检查qtpandas各个模块的所有语句,只有按上面的思路、方法,发现一个问题,解决一个问题吧。
在PyQt5中使用Pandas时的几个坑的更多相关文章
- 在Pycharm中使用Pandas时输出结果中列被省略的解决办法
在使用pycharm学习pandas的过程中我发现好多时候会发生不能输出所有列的情况,上网搜了一下,发现解决的办法是使用一个输出控制的函数. 在下面的代码中我们只是输出starbucks_store_ ...
- 记录在vue中使用jsx时踩过的坑
使用方法及细节就不一一说了. 1.给input或者textarea绑定value时,出现失效的问题.解决方法:https://github.com/vuejs/babel-plugin-transfo ...
- PyQt5中的信号与槽,js 与 Qt 对象之间互相调用
一.PyQt中的信号与槽 信号(Signal)和槽(Slot)是Qt中的核心机制,用在对象之间互相通信.在Qt中每个QObject对象和PyQt中所有继承自QWidget的控件(这些都是QObject ...
- 在php中定义常量时,const与define的区别?
问]在php中定义常量时,const与define的区别? [答]使用const使得代码简单易读,const本身就是一个语言结构,而define是一个函数.另外const在编译时要比define快很 ...
- AndRodi Strudio中的按钮时件
AndRodi Studio中的按钮时件注册一定要写在onCraete中 @Override protected void onCreate(Bundle savedInstanceState) { ...
- 在MySQL向表中插入中文时,出现:incorrect string value 错误
在MySQL向表中插入中文时,出现:incorrect string value 错误,是由于字符集不支持中文.解决办法是将字符集改为GBK,或UTF-8. 一.修改数据库的默认字符集 ...
- Android Tips: 在给drawable中添加图片资源时,文件名必须全小写
在给drawable中添加图片资源时,文件名必须全小写
- 在查询时将查询条件放入Session中,导出时直接根据qpniRGaFiler取查询条件即可
在查询时将查询条件放入Session中,导出时直接根据qpniRGaFiler取查询条件即可
- 使用ueditor中的setContent() 时经常报innerHtml错误(笔记)
1)今天遇到个问题,使用ueditor中的setContent() 时经常报innerHtml错误:网上找了下解决方案:发现这个可以用: 不能创建editor之后马上使用ueditor.setCont ...
随机推荐
- 记一次 .NET 某工控数据采集平台 线程数 爆高分析
一:背景 1. 讲故事 前几天有位朋友在 B站 加到我,说他的程序出现了 线程数 爆高的问题,让我帮忙看一下怎么回事,截图如下: 说来也奇怪,这些天碰到了好几起关于线程数无缘无故的爆高,不过那几个问题 ...
- 基于Vue3SSR渲染作品H5页
回顾 多项目之间的关系 业务组件sqxy-components为何要单独抽离出来? 整体思路 根据 id uuid来获取思路 判断 status(未发布,强制下线) 作品数据+leogo-cpmpon ...
- 2022徐特立科学营&BIT机器人队电控课程讲义
目录 \(\cdot\)电控简介 \(\cdot\)认识单片机 什么是单片机 时钟-单片机的脉搏 \(\cdot\)外设及应用 GPIO PWM 定时器 UART \(\cdo ...
- 手动从0搭建ABP框架-ABP官方完整解决方案和手动搭建简化解决方案实践
本文主要讲解了如何把ABP官方的在线生成解决方案运行起来,并说明了解决方案中项目间的依赖关系.然后手动实践了如何从0搭建了一个简化的解决方案.ABP官方的在线生成解决方案源码下载参考[3],手动搭 ...
- 从零开始Blazor Server(2)--整合数据库
开篇 上一篇文章我们留了个尾巴,没有把freesql整合进去,这篇文章我们来整合. 目前的思路呢,是做一个简单的四不像的RABC,也有用户.角色. 权限三部分. 但是其中每个用户只有一个角色,即用户和 ...
- 获取某个html元素相对于视窗的位置集合
getBoundingClientRect() getBoundingClientRect()获取元素位置,这个方法没有参数 getBoundingClientRect()用于获得页面中某个元素的左, ...
- 【freertos】013-任务通知及其实现细节
前言 参考: https://www.freertos.org/RTOS-task-notifications.html 原文:https://www.cnblogs.com/lizhuming/p/ ...
- Python 车主之家全系车型(包含历史停售车型)配置参数爬虫
本文仅供学习交流使用,如侵立删!demo下载见文末 车主之家全系车型(包含历史停售车型)配置参数爬虫 先上效果图 环境: win10 ,Contos7.4 python3.9.4 pycharm202 ...
- 436. 寻找右区间--LeetCode_暴力
来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/find-right-interval 著作权归领扣网络所有.商业转载请联系官方授权,非商业转载请注明出 ...
- iOS影视应用+全网视频下载
又一个新的iOS影视伪装 打开软件连续点击3次列表,然后关闭重新打开即可变身,无广告全免费高画质,还有电视直播 下载地址:https://apps.apple.com/cn/app/贴画壁纸/id16 ...