知识屋:更实用的电脑技术知识网站
所在位置:首页 > 编程技术 > PHP编程

python3+pywin32 获取用户定义的ODBC数据源

发布时间:2015-05-27 19:31:25作者:知识屋

windows下,通过读取注册表获取用户定义的数据源

[python] 
# -*- coding: UTF-8 -*- 
# 获取ODBC数据源列表 
from tkinter import * 
from tkinter import ttk 
import win32api,win32con 
 
 
def GetODBCdsn(): 
    key = win32api.RegOpenKey(win32con.HKEY_CURRENT_USER, 
    'SOFTWARE//ODBC//ODBC.INI//ODBC Data Sources',0, win32con.KEY_ALL_ACCESS) 
    #print(key) 
    #print(win32api.RegQueryValue(key,'')) 
    #print('返回项的子项数目、项值数目,以及最后一次修改时间',win32api.RegQueryInfoKey(key)) 
    subitem, item, opdate =win32api.RegQueryInfoKey(key) 
    dsnlist=[] 
    for i in range(item): 
        print('---',win32api.RegEnumValue(key, i)) 
        dsnName,dsnObject,dsnType = win32api.RegEnumValue(key, i) 
        dsnlist.append(dsnName) 
    #print(dir(win32api)) 
    win32api.RegCloseKey(key) 
    return dsnlist 
 
 
class MFrame(Frame): 
    def __init__(self, master=None, cnf={}, **kw): 
        self.master = master 
        self.master.title('获取用户定义的数据源') 
        self.combo = ttk.Combobox(self.master) 
        self.combo.config(state="readonly") 
        self.combo.pack(side=TOP, fill = 'x', expand = False) 
        self.combo.update_idletasks() 
        comlist=GetODBCdsn() 
        self.combo['values'] = comlist 
 
 
def test(): 
    GetODBCdsn() 
def main(): 
    root = Tk() 
    mf=MFrame(root) 
    root.mainloop() 
if __name__=="__main__": 
    #test() 
    main() 

(免责声明:文章内容如涉及作品内容、版权和其它问题,请及时与我们联系,我们将在第一时间删除内容,文章内容仅供参考)
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜