欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實現從SQL型數據庫讀寫dataframe型數據的方法【基于pandas】

 更新時間:2019年03月18日 10:01:20   作者:Arkenstone  
這篇文章主要介紹了Python實現從SQL型數據庫讀寫dataframe型數據的方法,涉及Python基于pandas的數據庫讀寫相關操作技巧,需要的朋友可以參考下

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

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

read_sql

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

  • sql:SQL命令字符串
  • con:連接sql數據庫的engine,一般可以用SQLalchemy或者pymysql之類的包建立
  • index_col: 選擇某一列作為index
  • coerce_float:非常有用,將數字形式的字符串直接以float型讀入
  • parse_dates:將某一列日期型字符串轉換為datetime型數據,與pd.to_datetime函數功能類似。可以直接提供需要轉換的列名以默認的日期形式轉換,也可以用字典的格式提供列名和轉換的日期格式,比如{column_name: format string}(format string:"%Y:%m:%H:%M:%S")。
  • columns:要選取的列。一般沒啥用,因為在sql命令里面一般就指定要選擇的列了
  • chunksize:如果提供了一個整數值,那么就會返回一個generator,每次輸出的行數就是提供的值的大小。
  • params:其他的一些執(zhí)行參數,沒用過不太清楚。。。

以鏈接常見的mysql數據庫為例:

import pandas as pd
import pymysql
import sqlalchemy
from sqlalchemy import create_engine
# 1. 用sqlalchemy構建數據庫鏈接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構建數據庫鏈接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中鏈接數據庫的URL格式:dialect[+driver]://user:password@host/dbname[?key=value..]。dialect代表書庫局類型,比如mysql, oracle, postgresql。driver代表DBAPI的名字,比如psycopg2,pymysql等。具體說明可以參考這里。此外由于數據里面有中文的時候就需要將charset設為utf8。

to_sql

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

  • name: 輸出的表名
  • con: 與read_sql中相同
  • if_exits: 三個模式:fail,若表存在,則不輸出;replace:若表存在,覆蓋原來表里的數據;append:若表存在,將數據寫到原表的后面。默認為fail
  • index:是否將df的index單獨寫到一列中
  • index_label:指定列作為df的index輸出,此時index為True
  • chunksize: 同read_sql
  • dtype: 指定列的輸出到數據庫中的數據類型。字典形式儲存:{column_name: sql_dtype}。常見的數據類型有sqlalchemy.types.INTEGER(), sqlalchemy.types.NVARCHAR(),sqlalchemy.Datetime()等,具體數據類型可以參考這里

還是以寫到mysql數據庫為例:

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會自動根據df列的dtype選擇默認的數據類型輸出,比如字符型會以sqlalchemy.types.TEXT類型輸出,相比NVARCHAR,TEXT類型的數據所占的空間更大,所以一般會指定輸出為NVARCHAR;而如果df的列的類型為np.int64時,將會導致無法識別并轉換成INTEGER型,需要事先轉換成int類型(用map,apply函數可以方便的轉換)。

參考:

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相關內容感興趣的讀者可查看本站專題:《Python常見數據庫操作技巧匯總》、《Python數學運算技巧總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總

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

相關文章

  • Python常用知識點匯總

    Python常用知識點匯總

    這篇文章主要介紹了Python常用知識點匯總,包括Set集合,函數,深入拷貝,淺入拷貝,需要的朋友可以參考下
    2016-05-05
  • Django各種緩存的配置小結 ?

    Django各種緩存的配置小結 ?

    本文主要介紹了Django各種緩存的配置小結 ,Django提供了多種緩存后端,如內存緩存、文件緩存、數據庫緩存、Memcached和Redis等,根據項目需求選擇合適的緩存后端,下面就一起來了解一下吧
    2023-08-08
  • 一文輕松了解Python中類的繼承

    一文輕松了解Python中類的繼承

    類的繼承可以看成對類的屬性和方法的重用,能夠大大的減少代碼量,下面這篇文章主要給大家介紹了關于Python中類的繼承的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • 在Ubuntu系統下安裝使用Python的GUI工具wxPython

    在Ubuntu系統下安裝使用Python的GUI工具wxPython

    這篇文章主要介紹了在Ubuntu系統下安裝使用Python的GUI工具wxPython的方法,wxPython可以為Python提供強大的圖形化界面開發(fā)支持,需要的朋友可以參考下
    2016-02-02
  • 通過python繪制華強買瓜的字符畫視頻的步驟詳解

    通過python繪制華強買瓜的字符畫視頻的步驟詳解

    要把華強賣瓜做成字符視頻大概分為三步,通過讀取視頻,把每一幀轉為字符畫,接著把字符畫表現出來,本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2021-11-11
  • Python函數參數的4種方式

    Python函數參數的4種方式

    本文主要介紹了Python函數參數的4種方式,主要包括必選參數,默認參數,可選參數,關鍵字參數,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • Pytorch之contiguous的用法

    Pytorch之contiguous的用法

    今天小編就為大家分享一篇Pytorch之contiguous的用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 老生常談Python序列化和反序列化

    老生常談Python序列化和反序列化

    下面小編就為大家?guī)硪黄仙U凱ython序列化和反序列化。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • pytorch關于Tensor的數據類型說明

    pytorch關于Tensor的數據類型說明

    這篇文章主要介紹了pytorch關于Tensor的數據類型說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Python中的tuple元組詳細介紹

    Python中的tuple元組詳細介紹

    這篇文章主要介紹了Python中的tuple元組詳細介紹,本文講解了Tuple 與 list 的相同之處、Tuple 不存在的方法、用 Tuple 的好處、Tuple 與 list 的轉換等內容,需要的朋友可以參考下
    2015-02-02

最新評論