| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> Pandas获取SQL数据库read_sql()函数及参数一文详解+实例代码 -> 正文阅读 |
|
[大数据]Pandas获取SQL数据库read_sql()函数及参数一文详解+实例代码 |
前言Pandas常用作数据分析工具库以及利用其自带的DataFrame数据类型做一些灵活的数据转换、计算、运算等复杂操作,但都是建立在我们获取数据源的数据之后。因此作为读取数据源信息的接口函数必然拥有其强大且方便的能力,在读取不同类源或是不同类数据时都有其对应的read函数可进行先一步处理,这会减少我们相当大的一部分数据处理操作。每一个read()函数,作为一名数据分析师我个人认为都应该掌握且熟悉它对应的参数,相对应的read()函数博主已有两篇文章详细解读了read_json和read_excel: Pandas处理JSON文件read_json()一文详解+代码展示 Pandas中read_excel函数参数使用详解+实例代码 下面博主将从官网文档以及自身函数用例来展示该函数的详细用法。? 一、基础语法与功能
共有8个可选参数:sql,con,index_col,coerce_float,params,parse_date,columns,chunksize。 该函数基础功能为将SQL查询或数据库表读入DataFrame。此函数是read_sql_table和read_sql_query(向后兼容性)两个函数功能结合。它将根据提供的输入参数传入给特定功能。一个SQL查询将传入到read_sql_query查询,而数据库表名称将路由到read_sql_table表。特定功能为SQL引擎驱动进行查询获取数据库内的数据。 二、参数说明和代码演示
上述为官网文档参数说明:Pandas.read_sql() ?首先我们将逐个了解每个参数的功能和作用,在了解参数意义后再进行实例使用。 要进行参数测试要先连接数据库,这里用本地环境进行测试: 首先打开mysql,要以管理员方式进入命令提示符: ?进入Jupyter,需要再引入pymysql库:
该库想要详细了解可以去博主的另一篇博文:?ython-pymysql库使用一文详解+实例代码 此库为连接mysql的接口函数:
?还需引入SQLalchemy库的创建引擎函数:
创建引擎:
1.sql接受类型:{str or SQLAlchemy Selectable (select or text object)} 这个SQLAlchemy Selectable就是SQL查询语法,该参数可以为执行的SQL查询或获取指定表名的数据。 展示:需求要读取metric_value这张sql数据表: 将一段sql查询语句作为参数传入,可获得sql查询的表转化的dataframe:?
?可以见到是和原sql表一样的内容: ?也可以将sql内的表名作为参数传入,可以获得该表的全部内容:
?2.con接受类型:{SQLAlchemy connectable, str, or sqlite3 connection} 使用SQLAlchemy可以使用该库支持的任何DB。如果是DBAPI2对象,则仅支持sqlite3。用户负责SQLAlchemy connectable的引擎处理和连接关闭;str连接将自动关闭。 con为python连接sql的sqlalchemy.engine,该参数也为必须输入的参数,可以使用SQLAlchemy数据库支持的连接引擎。上文已经创建这里不再进行操作。 3.index_col接受类型:{str or list of str, optional, default: None} 可指定参数为要设置为索引的列(多索引)。
?也可以设定多个索引,当然转化为dataframe之后用set_index也可以达到一样的效果,大家要是忘了如何操作dataframe的索引的话可以去博主的:一文速学-Pandas索引设置操作各类方法详解+代码展示?在看一遍就好了。
?4.coerce_float接受类型:{bool, default True} 尽力函数:将非字符串、非数字对象(如decimal.Decimal)的值转换为浮点,这对SQL结果集很有用。相当于将一些数据类型转换为浮点数据类型,True开着就行了。 5.params接受类型:{list, tuple or dict, optional, default: None}列表,元组,指定,默认为None。 可传入参数为要传递给execute方法的参数列表。用于传递参数的语法依赖于数据库驱动程序。查看数据库驱动程序文档,了解支持PEP 249的paramstyle中描述的五种语法样式中的哪一种。例如,对于psycopg2,指定需要使用%(name)s,所以使用params={'name':'value'}。 也就是可以以一个sql对于一个输出以这样的形式输出。 6.parse_dates接受类型:{list or dict, default: None}
原转化的DataFrame各个字段数据类型为: 现在我们将time也转化为datetime形式:
可见time转化为了datetime类型:? ? 这是使用了to_datetime()函数来达成该功能 ,导致直接使用unix从1970-0-0 00:00开始计算,不了解原理可以去看这篇:Pandas中to_datetime()转换时间序列函数一文详解 ?我们在后面加个format就能转换为我们想要的类型:
? 7.columns接受类型:{list, default: None} 从SQL表中选择的列名列表(仅在读取表时使用)。
8.chunksize接受类型:{int, default None} 如果指定,则返回一个迭代器,其中chunksize是每个块中要包含的行数。
得到一个SQLtable迭代类型: <generator object SQLTable._query_iterator at 0x0000026432FB4E48> 三、返回参数DataFrame or Iterator[DataFrame] 返回DataFrame或是SQL的迭代器。 点关注,防走丢,如有纰漏之处,请留言指教,非常感谢以上就是本期全部内容。我是fanstuck ,有问题大家随时留言讨论 ,我们下期见。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/13 8:00:39- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |