Pandas告警UserWarning:pandas only supports SQLAlchemy connectable处理方式

 更新时间:2024年02月13日 11:03:14   作者:smart_cat  
这篇文章主要给大家介绍了关于Pandas告警UserWarning:pandas only supports SQLAlchemy connectable的处理方式,文中还分享了pandas还有哪些userwarning,对大家学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、报错信息

使用老的书写方式从数据库导入数据到pandas, 会打出一条warning信息:

UserWarning: pandas only supports SQLAlchemy connectable (engine/connection) or database string URI or sqlite3 DBAPI2 connection. Other DBAPI2 objects are not tested. Please consider using SQLAlchemy.

二、老的书写方式

老的书写方式为:

import pymysql
import pandas as pd

db_host = 'localhost'
user = 'root'
passwd = '123456'
db = 'mytestdb'

conn = pymysql.connect(host=db_host,
                       user=user,
                       passwd=passwd,
                       db=db,
                       charset='utf8')

sql = 'SELECT * FROM students'

pd.set_option('display.unicode.ambiguous_as_wide', True)
pd.set_option('display.unicode.east_asian_width', True)
df = pd.read_sql(sql, conn)
print(df)

conn.close()

三、新的书写方式

按照提示,推荐使用SQLAlchemy,需要先安装SQLAlchemy库:

pip install sqlalchemy

新版本的pandas库中con参数使用sqlalchemy库创建的create_engine对象 。创建create_engine对象(格式类似于URL地址)

from sqlalchemy import create_engine
import pandas as pd

MYSQL_HOST = 'localhost'
MYSQL_PORT = '3306'
MYSQL_USER = 'root'
MYSQL_PASSWORD = '123456'
MYSQL_DB = 'mytestdb'

engine = create_engine('mysql+pymysql://%s:%s@%s:%s/%s?charset=utf8'
                           % (MYSQL_USER, MYSQL_PASSWORD, MYSQL_HOST, MYSQL_PORT, MYSQL_DB))

sql = 'SELECT * FROM students'

df = pd.read_sql(sql, engine)

pd.set_option('display.unicode.ambiguous_as_wide', True)
pd.set_option('display.unicode.east_asian_width', True)
print(df)

附:pandas还有哪些userwarning

当使用Pandas时,可能会遇到一些UserWarning。以下是一些可能会出现的UserWarning:

  1. Data Validation extension is not supported and will be removed: 这个警告来自openpyxl,当使用pandas读取Excel文件时,会出现这个警告。这个警告是关于一些规范的扩展,不影响数据的读取 1。
  2. pandas only supports SQLAlchemy connectable (engine/connection) or database string URI or sqlite3 DBAPI2 connection. Other DBAPI2 objects are not tested. Please consider using SQLAlchemy.: 当使用老的书写方式从数据库导入数据到pandas时,会出现这个警告。这个警告是关于使用SQLAlchemy连接数据库的建议 2。
  3. Pandas doesn’t allow columns to be created via a new attribute name: 当继承Pandas DataFrame时,如果通过新属性名创建列,则会出现这个警告 3。

以下是每种情况的代码示例:Data Validation extension is not supported and will be removed: 这个警告通常与Excel文件的读取有关,你可以使用openpyxl库的warnings模块来忽略这个警告,示例如下:

import openpyxl
import warnings
from openpyxl.utils.exceptions import DataValidationError

# 忽略DataValidationError的警告
warnings.simplefilter("ignore", category=DataValidationError)# 使用Pandas读取Excel文件
df = pd.read_excel('your_excel_file.xlsx')

pandas only supports SQLAlchemy connectable (engine/connection): 这个警告建议使用SQLAlchemy连接数据库。示例代码如下:

from sqlalchemy import create_engine

# 创建一个SQLAlchemy数据库连接
engine = create_engine('database_connection_string')# 使用SQLAlchemy连接从数据库导入数据到Pandas DataFrame
df = pd.read_sql_query('SELECT * FROM your_table', con=engine)

Pandas doesn't allow columns to be created via a new attribute name: 这个警告通常在继承Pandas DataFrame时出现,你应该避免通过新属性名创建列,而是使用标准的Pandas方式来创建列。示例代码如下:

import pandas as pd

# 创建一个空的DataFrame
df = pd.DataFrame()

# 使用标准方式创建列
df['column_name'] = [1, 2, 3, 4, 5]

# 避免使用新属性名创建列
# df.new_column = [6, 7, 8, 9, 10]  # 这会触发警告

这些示例代码可以帮助你处理这些Pandas UserWarning,并采取适当的措施以避免潜在的问题。

总结 

到此这篇关于Pandas告警UserWarning:pandas only supports SQLAlchemy connectable处理方式的文章就介绍到这了,更多相关Pandas告警UserWarning内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python中的查找算法代码实例

    Python中的查找算法代码实例

    这篇文章主要介绍了Python中的查找算法代码实例,算法是解决一系列问题的清晰指令,也就是,能对一定规范的输入,在有限的时间内获得所要求的输出,简单来说,算法就是解决一个问题的具体方法和步骤,算法是程序的灵魂,需要的朋友可以参考下
    2023-07-07
  • Python人工智能之路 jieba gensim 最好别分家之最简单的相似度实现

    Python人工智能之路 jieba gensim 最好别分家之最简单的相似度实现

    这篇文章主要介绍了Python人工智能之路 jieba gensim 最好别分家之最简单的相似度实现 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • Python的socket模块源码中的一些实现要点分析

    Python的socket模块源码中的一些实现要点分析

    我们平时引入Python的socket模块利用其中的方法可以轻松地写出搭建socket通信的程序,今天我们就来看一下Python的socket模块源码中的一些实现要点分析,领略Python简洁代码的一些背后功劳.
    2016-06-06
  • Python中的with语句与上下文管理器学习总结

    Python中的with语句与上下文管理器学习总结

    在Python中作为上下文管理器的对象可以使用with语句,提供上下文管理器的contextlib模块的使用则是Python编程中的高级技巧,下面我们就来详细整理一下Python中的with语句与上下文管理器学习总结:
    2016-06-06
  • Python实现的从右到左字符串替换方法示例

    Python实现的从右到左字符串替换方法示例

    这篇文章主要介绍了Python实现的从右到左字符串替换方法,涉及Python字符串遍历、运算、判断、替换等相关操作技巧,需要的朋友可以参考下
    2018-07-07
  • 使用Fastapi打包exe后无限启动导致死机的解决办法

    使用Fastapi打包exe后无限启动导致死机的解决办法

    将 fastapi 服务打包成 exe 后双击执行,命令行中不断创建服务导致cpu吃满,最后死机,所以本文给大家介绍了Fastapi打包exe后无限启动导致死机的解决办法,需要的朋友可以参考下
    2024-03-03
  • 基于Python编写简易的成语接龙游戏

    基于Python编写简易的成语接龙游戏

    成语接龙是中华民族传统的文字游戏。它历史悠久,是传统文字、文化、文明的一个缩影,也是老少皆宜的民间文化娱乐活动。本文将用Python制作一个简单的成语接龙游戏,需要的可以参考一下
    2022-03-03
  • python使用thrift教程的方法示例

    python使用thrift教程的方法示例

    这篇文章主要介绍了python使用thrift教程的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • python 录制系统声音的示例

    python 录制系统声音的示例

    这篇文章主要介绍了python 录制系统声音的示例,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-12-12
  • 教你学会使用Python正则表达式

    教你学会使用Python正则表达式

    正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。 Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式。re 模块使 Python 语言拥有全部的正则表达式功能。
    2017-09-09

最新评论