中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用Python實現從SQL型數據庫讀寫dataframe型數據的方法

發布時間:2021-04-07 10:54:20 來源:億速云 閱讀:246 作者:小新 欄目:開發技術

這篇文章主要介紹如何使用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:其他的一些執行參數,沒用過不太清楚。。。

以鏈接常見的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函數可以方便的轉換)。

以上是“如何使用Python實現從SQL型數據庫讀寫dataframe型數據的方法”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

饶阳县| 修文县| 巴林左旗| 巧家县| 富平县| 泉州市| 凌海市| 蕉岭县| 迁西县| 天全县| 科技| 临桂县| 高雄县| 朝阳县| 元阳县| 乌鲁木齐县| 南丰县| 临澧县| 郓城县| 湘乡市| 吉水县| 平阴县| 江阴市| 吉林省| 奇台县| 邻水| 中方县| 德清县| 永清县| 商南县| 盐津县| 杂多县| 丰城市| 隆化县| 永宁县| 孝感市| 吉首市| 高邑县| 樟树市| 镇康县| 永宁县|