日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python读取数据库数据类型_Python实现从SQL型数据库读写dataframe型数据的方法【基于pandas】...

發(fā)布時間:2025/3/11 python 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python读取数据库数据类型_Python实现从SQL型数据库读写dataframe型数据的方法【基于pandas】... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

本文實例講述了Python實現(xiàn)從SQL型數(shù)據(jù)庫讀寫dataframe型數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:

Python的pandas包對表格化的數(shù)據(jù)處理能力很強(qiáng),而SQL數(shù)據(jù)庫的數(shù)據(jù)就是以表格的形式儲存,因此經(jīng)常將sql數(shù)據(jù)庫里的數(shù)據(jù)直接讀取為dataframe,分析操作以后再將dataframe存到sql數(shù)據(jù)庫中。而pandas中的read_sql和to_sql函數(shù)就可以很方便得從sql數(shù)據(jù)庫中讀寫數(shù)據(jù)。

參見pandas.read_sql的文檔,read_sql主要有如下幾個參數(shù):

sql:SQL命令字符串

con:連接sql數(shù)據(jù)庫的engine,一般可以用SQLalchemy或者pymysql之類的包建立

index_col: 選擇某一列作為index

coerce_float:非常有用,將數(shù)字形式的字符串直接以float型讀入

parse_dates:將某一列日期型字符串轉(zhuǎn)換為datetime型數(shù)據(jù),與pd.to_datetime函數(shù)功能類似。可以直接提供需要轉(zhuǎn)換的列名以默認(rèn)的日期形式轉(zhuǎn)換,也可以用字典的格式提供列名和轉(zhuǎn)換的日期格式,比如{column_name: format string}(format string:"%Y:%m:%H:%M:%S")。

columns:要選取的列。一般沒啥用,因為在sql命令里面一般就指定要選擇的列了

chunksize:如果提供了一個整數(shù)值,那么就會返回一個generator,每次輸出的行數(shù)就是提供的值的大小。

params:其他的一些執(zhí)行參數(shù),沒用過不太清楚。。。

以鏈接常見的mysql數(shù)據(jù)庫為例:

import pandas as pd

import pymysql

import sqlalchemy

from sqlalchemy import create_engine

# 1. 用sqlalchemy構(gòu)建數(shù)據(jù)庫鏈接engine

connect_info = 'mysql+pymysql://{}:{}@{}:{}/{}?charset=utf8'.format(DB_USER, DB_PASS, DB_HOST, DB_PORT, DATABASE) #1

engine = create_engine(connect_info)

# sql 命令

sql_cmd = "SELECT * FROM table"

df = pd.read_sql(sql=sql_cmd, con=engine)

# 2. 用DBAPI構(gòu)建數(shù)據(jù)庫鏈接engine

con = pymysql.connect(host=localhost, user=username, password=password, database=dbname, charset='utf8', use_unicode=True)

df = pd.read_sql(sql_cmd, con)

解釋一下 #1: 這個是sqlalchemy中鏈接數(shù)據(jù)庫的URL格式:dialect[+driver]://user:password@host/dbname[?key=value..]。dialect代表書庫局類型,比如mysql, oracle, postgresql。driver代表DBAPI的名字,比如psycopg2,pymysql等。具體說明可以參考這里。此外由于數(shù)據(jù)里面有中文的時候就需要將charset設(shè)為utf8。

參見pandas.to_sql函數(shù),主要有以下幾個參數(shù):

name: 輸出的表名

con: 與read_sql中相同

if_exits: 三個模式:fail,若表存在,則不輸出;replace:若表存在,覆蓋原來表里的數(shù)據(jù);append:若表存在,將數(shù)據(jù)寫到原表的后面。默認(rèn)為fail

index:是否將df的index單獨(dú)寫到一列中

index_label:指定列作為df的index輸出,此時index為True

chunksize: 同read_sql

dtype: 指定列的輸出到數(shù)據(jù)庫中的數(shù)據(jù)類型。字典形式儲存:{column_name: sql_dtype}。常見的數(shù)據(jù)類型有sqlalchemy.types.INTEGER(), sqlalchemy.types.NVARCHAR(),sqlalchemy.Datetime()等,具體數(shù)據(jù)類型可以參考這里

還是以寫到mysql數(shù)據(jù)庫為例:

df.to_sql(name='table',

con=con,

if_exists='append',

index=False,

dtype={'col1':sqlalchemy.types.INTEGER(),

'col2':sqlalchemy.types.NVARCHAR(length=255),

'col_time':sqlalchemy.DateTime(),

'col_bool':sqlalchemy.types.Boolean

})

注:如果不提供dtype,to_sql會自動根據(jù)df列的dtype選擇默認(rèn)的數(shù)據(jù)類型輸出,比如字符型會以sqlalchemy.types.TEXT類型輸出,相比NVARCHAR,TEXT類型的數(shù)據(jù)所占的空間更大,所以一般會指定輸出為NVARCHAR;而如果df的列的類型為np.int64時,將會導(dǎo)致無法識別并轉(zhuǎn)換成INTEGER型,需要事先轉(zhuǎn)換成int類型(用map,apply函數(shù)可以方便的轉(zhuǎn)換)。

參考:

http://docs.sqlalchemy.org/en/latest/core/type_basics.html#sql-standard-and-multiple-vendor-types

http://pandas.pydata.org/pandas-docs/stable/generated/pandas.read_sql.html

http://docs.sqlalchemy.org/en/latest/core/engines.html

http://docs.sqlalchemy.org/en/latest/core/type_basics.html#sql-standard-and-multiple-vendor-types

http://stackoverflow.com/questions/30631325/writing-to-mysql-database-with-pandas-using-sqlalchemy-to-sql

http://stackoverflow.com/questions/5687718/how-can-i-insert-data-into-a-mysql-database

http://stackoverflow.com/questions/32235696/pandas-to-sql-gives-unicode-decode-error

http://stackoverflow.com/questions/34383000/pandas-to-sql-all-columns-as-nvarchar

希望本文所述對大家Python程序設(shè)計有所幫助。

總結(jié)

以上是生活随笔為你收集整理的python读取数据库数据类型_Python实现从SQL型数据库读写dataframe型数据的方法【基于pandas】...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产一区二区三区在线 | 日韩一区二区免费播放 | 亚洲爽妇网 | 精品久久久久久久久久久久久 | sese视频在线观看 | 日韩久久久 | 亚洲国产视频一区二区三区 | 色又色| 在线观看免费黄视频 | 啪啪av导航 | av中文字幕一区二区三区 | 成人国产精品免费观看视频 | 又黄又爽视频 | 国产乡下妇女三片 | youjizz亚洲女人 | 成人午夜精品福利 | 久久久久网| 在线观看少妇 | jizz黑人| 国产日韩欧美精品一区二区 | 国产一久久 | 91社区在线播放 | 日韩美女中文字幕 | 精品人妻无码一区二区三区换脸 | 2018av在线| 久久成人久久 | 亚洲人成人 | 三级特黄视频 | 精品96久久久久久中文字幕无 | 色欲AV无码精品一区二区久久 | 国产国语亲子伦亲子 | 黄色福利网站 | 狠狠干av | 亚洲综合精品视频 | 国产精品一区二区在线免费观看 | 人妻激情偷乱视频一区二区三区 | 亚洲av综合永久无码精品天堂 | 少妇做爰免费理伦电影 | 亚洲精品18在线观看 | 亚洲国产不卡 | а√天堂www在线天堂小说 | 成人四色 | 最近国语视频在线观看免费播放 | 国产精品欧美久久久久久 | 精品一区二三区 | 国产福利一区二区三区视频 | 国产欧美日韩视频在线观看 | 午夜诱惑痒痒网 | 男女爱爱动态图 | 欧美aaa视频 | 欧美人与性动交a欧美精品 日韩免费高清视频 | 黄色一级片久久 | 91在线免费观看网站 | 国产免费一区二区三区视频 | 天堂二区 | 欧美videos另类精品 | 免费在线看污片 | 污污网站在线观看 | 人妻少妇精品无码专区 | 国模私拍视频在线 | 中文字幕精品久久久 | 国产精品欧美精品 | 经典杯子蛋糕日剧在线观看免费 | 日一日射一射 | 日韩最新网址 | 国产欧美在线播放 | 天天操狠狠操夜夜操 | 欧美做受xxxxxⅹ性视频 | 九九色精品 | 日韩视频在线观看 | 人人插人人看 | 青青操在线观看视频 | 午夜影院污 | 色女生影院 | 91麻豆映画传媒 | av首页在线观看 | 亚洲精品视频一区 | 91最新视频 | 久久久久免费精品视频 | 亚洲少妇18p | 欧美色图国产精品 | 天堂影音| 免费三级网 | 人操人操 | 婷婷视频在线观看 | 国产三级在线免费 | 亚洲 在线| 最近更新中文字幕 | 久久av免费看 | 久久一卡二卡 | 黄色国产在线 | 精品国产理论 | 国产99久久九九精品无码 | 男操女视频免费 | 天天爽夜夜爽夜夜爽 | 国产精品女优 | 亚洲天堂毛片 | 国产高清视频网站 | 操到喷水|