Heim  >  Artikel  >  Backend-Entwicklung  >  python3+pywin32 获取用户定义的ODBC数据源_PHP教程

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

WBOY
WBOYOriginal
2016-07-14 10:06:431146Durchsuche

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() 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/477920.htmlTechArticlewindows下,通过读取注册表获取用户定义的数据源 [python] # -*- coding: UTF-8 -*- # 获取ODBC数据源列表 from tkinter import * from tkinter import ttk import w...
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn