程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> 在Linux中通過Python腳本訪問mdb數據庫的方法

在Linux中通過Python腳本訪問mdb數據庫的方法

編輯:更多關於編程

       這篇文章主要介紹了在Linux中通過Python腳本訪問mdb數據庫的方法,本文示例基於debian系的Linux系統,需要的朋友可以參考下

      在 linux 系統中連接 mdb 數據庫,直接連接的話,mdb 默認的驅動無法識別非 windows 的路徑, 所以不能使用常規的連接方式

      ?

    1 DRIVER={Microsoft Access Driver (*.mdb)};DBQ=c:dirfile.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 為例

      ?

    1 2 3 4 5 6 7 8 #-*- 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

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

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

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved