PowerShell實(shí)現(xiàn)查詢打開(kāi)某個(gè)文件的默認(rèn)應(yīng)用程序
許多文件擴(kuò)展名和一個(gè)可執(zhí)行應(yīng)用程序綁定。正因?yàn)檫@樣你才可以使用Invoke-Item打開(kāi)一個(gè)文檔。
要找出一個(gè)給定后綴名的文件是由那個(gè)默認(rèn)引用程序打開(kāi)它,并不麻煩。我們可以使用Windows系統(tǒng)中的注冊(cè)表,自行編程解決。但是在掃描注冊(cè)表時(shí),要稍微留意一下32位和64位機(jī)器的問(wèn)題,這不是本文重點(diǎn),點(diǎn)到為止。
另外一種途徑,稍顯旁門左道,調(diào)用Windows API。下面的例子會(huì)演示如何調(diào)用。采取這種途徑最大的優(yōu)勢(shì)是借力于操作系統(tǒng)。而你的付出成本只是用C#代碼間接調(diào)用Windows API中的函數(shù)而已:
$Source = @"
using System;
using System.Text;
using System.Runtime.InteropServices;
public class Win32API
{
[DllImport("shell32.dll", EntryPoint="FindExecutable")]
public static extern long FindExecutableA(string lpFile, string lpDirectory, StringBuilder lpResult);
public static string FindExecutable(string pv_strFilename)
{
StringBuilder objResultBuffer = new StringBuilder(1024);
long lngResult = 0;
lngResult = FindExecutableA(pv_strFilename, string.Empty, objResultBuffer);
if(lngResult >= 32)
{
return objResultBuffer.ToString();
}
return string.Format("Error: ({0})", lngResult);
}
}
"@
Add-Type -TypeDefinition $Source -ErrorAction SilentlyContinue
$FullName = 'c:\Windows\windowsupdate.log'
$Executable = [Win32API]::FindExecutable($FullName)
"$FullName will be launched by $Executable"
唯一有個(gè)限制,就是FindExecutable()需要檢查的文件是存在的,你不能只用文件擴(kuò)展名去請(qǐng)求。
另外@reidca反饋說(shuō)該方法不能檢測(cè)MMC加載項(xiàng)打開(kāi)的文件,比如cer和pfx證書文件,程序會(huì)崩潰。
相關(guān)文章
探索PowerShell(十五) 引號(hào)與轉(zhuǎn)義字符
在PowerShell中,單引號(hào)與雙引號(hào)有著不同的功能和作用。引號(hào)的使用規(guī)則往往跟變量的代換,以及特殊字符有關(guān)2012-12-12
PowerShell中查找字符串位置的IndexOf函數(shù)使用實(shí)例
這篇文章主要介紹了PowerShell中查找字符串位置的IndexOf函數(shù)使用實(shí)例,例子簡(jiǎn)單明了,容易看懂,需要的朋友可以參考下2014-08-08
PowerShell實(shí)現(xiàn)在字符串中查找大寫字母
這篇文章主要介紹了PowerShell實(shí)現(xiàn)在字符串中查找大寫字母,本文講解使用.NET中的IsUpper()函數(shù)來(lái)實(shí)現(xiàn)查找大寫字母的需求,需要的朋友可以參考下2015-06-06
PowerShell Out-File追加字符串到文件末尾的方法
這篇文章主要介紹了PowerShell Out-File追加字符串到文件末尾的方法,只要加一個(gè)-Append參數(shù)即可實(shí)現(xiàn)追加內(nèi)容需求,需要的朋友可以參考下2014-08-08
PowerShell中直接輸出轉(zhuǎn)義字符或變量名稱的方法
這篇文章主要介紹了PowerShell中直接輸出轉(zhuǎn)義字符或變量名稱的方法,也就是原樣輸出字符串,不理會(huì)字符串可能包含的換行符、變量等,需要的朋友可以參考下2014-08-08
使用PowerShell將Excel工作表另存為獨(dú)立文件
這篇文章主要為大家介紹了如何使用?PowerShell?腳本將一個(gè)?Excel?文件中的每個(gè)工作表單獨(dú)另存為獨(dú)立的?Excel?文件,以提高工作效率,需要的可以參考一下2023-08-08

