• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

        如何在Windows設置系統中改變文件打開方式

        如何在Windows設置系統中改變文件打開方式

        更新時間:2022-05-14 文章作者:未知 信息來源:網絡 閱讀次數:

        在Windows 95/NT/98操作系統中改變文件打開方式的問題,又可稱為改變文件類型關聯的問題,即把某類型(擴展名)的文件與某應用程序關聯,例如通常當雙擊*.txt文件時系統自動調用Notepad.exe。本文介紹利用Windows注冊表編輯器Regedit.exe手工或編程改變文件打開方式的方法,并提供程序實例。
          一、基本思路:
          1、注冊表編輯器Regedit.exe是用于更改系統注冊表設置的高級工具,包含了關于系統配置及運行的重要信息,默認訪問路徑為C:\Windows\Regedit.exe。雙擊Regedit.exe圖標,運行注冊表編輯器。在左側顯示欄內看到HKEY_CLASSES_ROOT、KEY_CURRENT_USER、HKEY_LOCAL_MACHINE等主鍵。與文件類型有關的所有主鍵、鍵名、鍵值都存放在HKEY_CLASSES_ROOT下。
          ◆雙擊HKEY_CLASSES_ROOT,向下拖動滾動條,找到.txt主鍵,右側顯示欄內“txtfile”說明:在HKEY_CLASSES_ROOT下有一txtfile主鍵,其下存放了打開*.txt文件應用程序的有關信息。
          ◆向下拖動滾動條,找到txtfile主鍵,右側顯示欄內“文本文檔”為文件類型描述。雙擊txtfile,DefaultIcon右側顯示欄內“shell32.dll,-152”為*.txt文件的圖標;shell\open\command,右側顯示欄內“C:\WINDOWS\NOTEPAD.EXE %1”為打開*.txt文件的應用程序名稱及參數。  改變打開文件方式的方法(例如用VISIO打開*.exc文件):
          ◆手工:打開系統注冊表,在HKEY_CLASSES_ROOT下找到.exc及另一主鍵名,找到此主鍵,將shell\open\command右側顯示欄內“C:\WINDOWS\NOTEPAD.EXE %1”改為“C:\VISIO.EXE %1”(假設VISIO.EXE的訪問路徑是C:\,具體視情況而定),按F5刷新系統注冊表。
          ◆編程:利用VB、Delphi、C++Builder等讀寫系統注冊表,可自動改變文件打開方式。本文提供VB、Delphi編程實例。
          二、編程實例:
          ㈠利用VB編程
          1、在VB5.0 IDE中,新建工程Project1,在Form1上添加命令按鈕Command1。
          2、選擇菜單“工程”—“添加模塊”—“模塊”—“打開”,在Project1中添加模塊Moudle1。
          3、在Moudle1“通用—聲明”部分聲明API函數和常量。
          Const REG_SZ = 1
          Global Const HKEY_CLASSES_ROOT = &H80000000
        Declare Function OSRegQueryValueEx Lib “advapi32”Alias “RegQueryValueExA”(ByVal hKey As Long, ByVal lpszValueName As String,
        ByVal dwReserved As Long, lpdwType As Long, lpbData As Any, cbData As Long) As Long
        Declare Function OSRegOpenKey Lib “advapi32”Alias “RegOpenKeyA”(ByVal hKey As Long, ByVal lpszSubKey As String, phkResult As Long) As Long
        Declare Function OSRegSetValueEx Lib“advapi32”Alias “RegSetValueExA”(ByVal hKey As Long, ByVal lpszValueName As String,
        ByVal dwReserved As Long, ByVal fdwType As Long, lpbData As Any, ByVal cbData As Long) As Long
        Declare Function OSRegCloseKey Lib“advapi32”Alias “RegCloseKey”(ByVal hKey As Long) As Long
          4、在Moudle 1中編寫函數。
          Function RegOpenKey(ByVal hKey As Long, ByVal lpszSubKey As String,
        phkResult As Long) As Boolean
           Dim lResult As Long
           On Error GoTo 0 ` 關閉錯誤陷阱
           lResult = OSRegOpenKey(hKey, lpszSubKey, phkResult)
           If lResult = 0 Then
           RegOpenKey = True
           Else
           RegOpenKey = False
           End If
          End Function
          Function RegSetStringValue(ByVal hKey As Long, ByVal strValueName As String,
        ByVal strData As String, Optional ByVal fLog) As Boolean
           Dim lResult As Long
           On Error GoTo 0
           lResult = OSRegSetValueEx(hKey, strValueName, 0&, REG_SZ, ByVal strData,
        LenB(StrConv(strData, vbFromUnicode)) + 1)
           If lResult = 0 Then
           RegSetStringValue = True
           Else
           RegSetStringValue = False
           End If
          End Function
          Function StripTerminator(ByVal strString As String) As String
           Dim intZeroPos As Integer
           intZeroPos = InStr(strString, Chr$(0))
           If intZeroPos > 0 Then
          StripTerminator=Left$(strString, intZeroPos - 1)
           Else
           StripTerminator = strString
           End If
          End Function
          Function RegQueryStringValue(ByVal hKey As Long, ByVal strValueName As String,
        strData As String) As Boolean
           Dim lResult As Long
           Dim lValueType As Long
           Dim strBuf As String
           Dim lDataBufSize As Long
           RegQueryStringValue = False
           On Error GoTo 0
           lResult = OSRegQueryValueEx(hKey, strValueName, 0&, lValueType, ByVal 0&,
        lDataBufSize)
           If lResult = ERROR_SUCCESS Then
           If lValueType = REG_SZ Then
           strBuf = String(lDataBufSize, “”)
           lResult = OSRegQueryValueEx(hKey, strValueName, 0&, 0&, ByVal strBuf,
        lDataBufSize)
           If lResult = ERROR_SUCCESS Then
           RegQueryStringValue = True
           strData = StripTerminator(strBuf)
           End If
           End If
           End If
          End Function
          5、雙擊Command1,編寫Click事件代碼。
          Private Sub Command1_Click()
           Dim hKey As Long
           Dim MyReturn As Long
           Dim MyData As String
           MyReturn = OSRegOpenKey(HKEY_CLASSES_ROOT, “.exc”, hKey)
          MyReturn=RegQueryStringValue(hKey,“”,MyData)
          MyReturn=OSRegOpenKey(HKEY_CLASSES_ROOT, MyData+“\shell\open\command”,hKey)
           MyReturn = RegSetStringValue(hKey,“”,“c:\visio.exe 1%”, False)
           If MyReturn Then
           MsgBox “改變文件打開方式成功!”,vbInformation,“請注意”
           Else
           MsgBox “改變文件打開方式失敗!”,vbExclamation,“請注意”
           End If
           OSRegCloseKey (hKey)
          End Sub
          6、按F5運行程序,在簡體中文Windows95/NT/98、VB5.0/6.0環境中調試通過。

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統下載排行

        主站蜘蛛池模板: 亚洲国产成人久久精品影视| 天天干在线免费视频| 国产AV无码专区亚洲AWWW| 国产精品亚洲综合一区在线观看 | 无码乱人伦一区二区亚洲一| 91av免费在线视频| 国产成人亚洲影院在线观看| 黄床大片30分钟免费看| 亚洲成a人一区二区三区| 四虎一区二区成人免费影院网址| 又爽又高潮的BB视频免费看| 免费在线观看亚洲| 亚洲中文字幕无码一区| 欧洲人成在线免费| 亚洲毛片免费观看| 国外成人免费高清激情视频| 国产精品亚洲AV三区| 自拍偷自拍亚洲精品被多人伦好爽| 中文字幕看片在线a免费| 久久亚洲一区二区| 18女人水真多免费高清毛片| 亚洲国产熟亚洲女视频| 啊灬啊灬别停啊灬用力啊免费看| 在线播放国产不卡免费视频| 久久精品国产亚洲| 欧洲精品成人免费视频在线观看| 亚洲6080yy久久无码产自国产| 亚洲成av人片天堂网老年人| 免费在线中文日本| 亚洲天堂2016| 精品国产亚洲一区二区在线观看| 99国产精品免费视频观看| 亚洲精品二三区伊人久久| 亚洲精品网站在线观看不卡无广告 | 国产免费久久精品99re丫y| 亚洲日韩亚洲另类激情文学| 亚洲无线一二三四区手机| 国产精品白浆在线观看免费| 学生妹亚洲一区二区| 亚洲一区二区三区在线视频| 91福利视频免费观看|