在Linux中通过Python脚本访问mdb数据库的方法
投稿:goldensun
这篇文章主要介绍了在Linux中通过Python脚本访问mdb数据库的方法,本文示例基于debian系的Linux系统,需要的朋友可以参考下
在 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
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 pyodbc conn = pyodbc.connect('DSN=test'); cursor = conn.cursor() cursor.execute('select * from "省"') for row in cursor.fetchall(): print row.Name
注:如果是操作名称中文的表或者字段等,需要将其包含在双引号中,不然会出错,当然,将表名做成中文这么二的做法, 还是不推荐使用的啦
pyodbc 是个很不错的库,api 也很好用,不过对中文支持的并不好,它并没有默认以 unicode 处理数据,所以对于中文相关的应用, 编码问题无处不在,只得慢慢折腾了。
您可能感兴趣的文章:
- Python3.7 pyodbc完美配置访问access数据库
- 详解js文件通过python访问数据库方法
- 对Python通过pypyodbc访问Access数据库的方法详解
- Python使用pyodbc访问数据库操作方法详解
- Python轻量级ORM框架Peewee访问sqlite数据库的方法详解
- Python的Tornado框架实现异步非阻塞访问数据库的示例
- Linux下通过python访问MySQL、Oracle、SQL Server数据库的方法
- python访问mysql数据库的实现方法(2则示例)
- python使用MySQLdb访问mysql数据库的方法
- Python访问纯真IP数据库脚本分享
- Shell、Perl、Python、PHP访问 MySQL 数据库代码实例
- python访问纯真IP数据库的代码
- 使用Python通过oBIX协议访问Niagara数据的示例