在Linux中通過Python指令碼訪問mdb資料庫的方法

來源:互聯網
上載者:User
在 linux 系統中串連 mdb 資料庫,直接連接的話,mdb 預設的驅動無法識別非 windows 的路徑, 所以不能使用常規的串連 方式

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

安裝

這裡我們需要藉助一些庫來實現第三方的驅動

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

如果是支援 deb 的系統中,如果不能找到 libmdbodbc ,將以下路徑加入到軟體源列表中

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

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

安裝了需要的包後,需要做一些配置,才能支援 libmdbodbc 的驅動

複製代碼 代碼如下:

/etc/odbcinst.ini

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

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

複製代碼 代碼如下:

[test]
Description = Microsoft Access Try DB
Driver = MDBToolsODBC
Database = /path/to/mdb/file/test.mdb
Servername = localhost
Username =
Password =
port = 5432

代碼

配置好資料來源後,就可以用於任何支援 odbc 訪問的應用中了,這裡以 pyodbc 為例

#-*- coding: utf-8 -*-import pyodbcconn = pyodbc.connect('DSN=test');cursor = conn.cursor()cursor.execute('select * from "省"')for row in cursor.fetchall(): print row.Name

註:如果是操作名稱中文的表或者欄位等,需要將其包含在雙引號中,不然會出錯,當然,將表名做成中文這麼二的做法, 還是不推薦使用的啦

pyodbc 是個很不錯的庫,api 也很好用,不過對中文支援的並不好,它並沒有預設以 unicode 處理資料,所以對於中文相關的應用, 編碼問題無處不在,只得慢慢折騰了。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.