日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

在Linux中通過Python腳本訪問mdb數(shù)據(jù)庫的方法

系統(tǒng) 2077 0

在 linux 系統(tǒng)中連接 mdb 數(shù)據(jù)庫,直接連接的話,mdb 默認(rèn)的驅(qū)動無法識別非 windows 的路徑, 所以不能使用常規(guī)的連接 方式

            
DRIVER={Microsoft Access Driver (*.mdb)};DBQ=c:\\dir\\file.mdb


          

安裝

這里我們需要借助一些庫來實現(xiàn)第三方的驅(qū)動

我們需要安裝這些包:mdbtools, unixODBC, libmdbodbc

如果是支持 deb 的系統(tǒng)中,如果不能找到 libmdbodbc ,將以下路徑加入到軟件源列表中

deb http://ftp.de.debian.org/debian squeeze main

更新源后即可可以安裝 libmdbodbc 了
配置

安裝了需要的包后,需要做一些配置,才能支持 libmdbodbc 的驅(qū)動

復(fù)制代碼 代碼如下:
/etc/odbcinst.ini

[MDBToolsODBC]
Description = MDB Tools ODBC
Driver = /usr/lib/libmdbodbc.so.0
Setup =
FileUsage =
CPTimeout =
CPReuse =

/etc/odbc.ini 或者 ~/.odbc.ini

復(fù)制代碼 代碼如下:
[test]
Description = Microsoft Access Try DB
Driver = MDBToolsODBC
Database = /path/to/mdb/file/test.mdb
Servername = localhost
Username =
Password =
port = 5432

代碼

配置好數(shù)據(jù)源后,就可以用于任何支持 odbc 訪問的應(yīng)用中了,這里以 pyodbc 為例

            
#-*- coding: utf-8 -*-
import pyodbc

conn = pyodbc.connect('DSN=test');
cursor = conn.cursor()
cursor.execute('select * from "省"')
for row in cursor.fetchall():
 print row.Name


          

注:如果是操作名稱中文的表或者字段等,需要將其包含在雙引號中,不然會出錯,當(dāng)然,將表名做成中文這么二的做法, 還是不推薦使用的啦

pyodbc 是個很不錯的庫,api 也很好用,不過對中文支持的并不好,它并沒有默認(rèn)以 unicode 處理數(shù)據(jù),所以對于中文相關(guān)的應(yīng)用, 編碼問題無處不在,只得慢慢折騰了。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 义马市| 休宁县| 云林县| 前郭尔| 大荔县| 昌图县| 定远县| 长春市| 西畴县| 县级市| 获嘉县| 吉林省| 澄迈县| 巴楚县| 通榆县| 赤水市| 枝江市| 资源县| 开鲁县| 桐城市| 五台县| 杭锦后旗| 彭阳县| 来宾市| 东丽区| 浦北县| 额济纳旗| 宁陵县| 英吉沙县| 昂仁县| 石泉县| 兴山县| 南丹县| 瓦房店市| 玉田县| 合山市| 炉霍县| 清丰县| 乌什县| 东乌| 洪江市|