C#/.NET使用git命令行來(lái)操作git倉(cāng)庫(kù)的方法示例
我們可以在命令行中操作 git,但是作為一名程序員,如果在大量重復(fù)的時(shí)候還手動(dòng)敲命令行,那就太笨了。
本文介紹使用 C# 編寫(xiě)一個(gè) .NET 程序來(lái)自動(dòng)化地使用 git 命令行來(lái)操作 git 倉(cāng)庫(kù)。
這是一篇很基礎(chǔ)的入門文章。
最簡(jiǎn)單的運(yùn)行 git 命令的代碼
在 .NET 中,運(yùn)行一個(gè)命令只需要使用 Process.Start
開(kāi)啟一個(gè)子進(jìn)程就好了。于是要運(yùn)行一個(gè) git
命令,我們其實(shí)只需要這句足以:
Process.Start("git", "status");
當(dāng)然,直接能簡(jiǎn)寫(xiě)成 git
是因?yàn)?git.exe
在我的環(huán)境變量里面,一般開(kāi)發(fā)者在安裝 Git 客戶端的時(shí)候,都會(huì)自動(dòng)將此命令加入到環(huán)境變量。如果沒(méi)有,你需要使用完整路徑 C:\Program Files\Git\mingw64\bin\git.exe
只是每個(gè)人的路徑可能不同,所以這是不靠譜的。
允許獲得命令的輸出
對(duì)于上節(jié)中寫(xiě)的 Process.Start
,你一眼就能看出來(lái)這是完全沒(méi)有用的代碼。因?yàn)?git status
命令只是獲得倉(cāng)庫(kù)當(dāng)前的狀態(tài),這個(gè)命令完全不影響倉(cāng)庫(kù),只是為了看狀態(tài)的。
所以,命令最好要能夠獲得輸出。
而要獲得輸出,你需要使用 ProcessStartInfo
來(lái)指定如何啟動(dòng)一個(gè)進(jìn)程。
var info = new ProcessStartInfo(ExecutablePath, arguments) { CreateNoWindow = true, RedirectStandardOutput = true, UseShellExecute = false, WorkingDirectory = WorkingDirectory, };
需要設(shè)置至少這四個(gè)屬性:
CreateNoWindow
表示不要為這個(gè)命令單獨(dú)創(chuàng)建一個(gè)控制臺(tái)窗口
實(shí)際上如果使用此代碼的程序也是一個(gè)控制臺(tái)程序,這句是沒(méi)有必要的,因?yàn)樽舆M(jìn)程會(huì)共用父進(jìn)程的控制臺(tái)窗口;但是對(duì)于 GUI 程序來(lái)說(shuō),這句還是很重要的,這可以避免在執(zhí)行命令的過(guò)程中意外彈出一個(gè)黑色的控制臺(tái)窗口出來(lái)。
RedirectStandardOutput
進(jìn)行輸出的重定向
這是一定要設(shè)置為 true
的屬性,因?yàn)槲覀兿M玫矫畹妮敵鼋Y(jié)果。
WorkingDirectory
設(shè)置工作路徑
本來(lái)這是一個(gè)可選設(shè)置,不過(guò)對(duì)于 git
命令來(lái)說(shuō),一般都是對(duì)一個(gè)已有的 git 倉(cāng)庫(kù)進(jìn)行操作,所以當(dāng)然要指定一個(gè)合理的 git 倉(cāng)庫(kù)了。
UseShellExecute
設(shè)置為false
表示不要使用ShellExecute
函數(shù)創(chuàng)建進(jìn)程
此屬性的詳細(xì)說(shuō)明,
UseShellExecute 的默認(rèn)值是 true
。
如果有以下需求,那么建議設(shè)置此值為 false
:
- 需要明確執(zhí)行一個(gè)已知的程序
- 需要重定向輸入和輸出
如果你有以下需求,那么建議設(shè)置此值為 true 或者保持默認(rèn):
- 需要打開(kāi)文檔、媒體、網(wǎng)頁(yè)文件等
- 需要打開(kāi) Url
- 需要打開(kāi)腳本執(zhí)行
- 需要打開(kāi)計(jì)算機(jī)上環(huán)境變量中路徑中的程序
這里我們必須指定為 false
,因?yàn)橐囟ㄏ蜉敵龅脑?,這是唯一有效值。順便一提,此屬性如果不設(shè)置,默認(rèn)值是 true
。
CommandRunner
為了方便起見(jiàn),我將全部運(yùn)行一個(gè)命令的代碼封裝到了一個(gè) CommandRunner
的類當(dāng)中。
using System; using System.Diagnostics; using System.IO; namespace Walterlv.GitDemo { public class CommandRunner { public string ExecutablePath { get; } public string WorkingDirectory { get; } public CommandRunner(string executablePath, string workingDirectory = null) { ExecutablePath = executablePath ?? throw new ArgumentNullException(nameof(executablePath)); WorkingDirectory = workingDirectory ?? Path.GetDirectoryName(executablePath); } public string Run(string arguments) { var info = new ProcessStartInfo(ExecutablePath, arguments) { CreateNoWindow = true, RedirectStandardOutput = true, UseShellExecute = false, WorkingDirectory = WorkingDirectory, }; var process = new Process { StartInfo = info, }; process.Start(); return process.StandardOutput.ReadToEnd(); } } }
測(cè)試與結(jié)果
以上 CommandRunner
命令的使用非常簡(jiǎn)單, new
出來(lái)之后,得到一個(gè)可以用來(lái)執(zhí)行命令的實(shí)例,然后每次執(zhí)行調(diào)用 Run
方法傳入?yún)?shù)即可。
var git = new CommandRunner("git", @"D:\Developments\Blogs\walterlv.github.io"); git.Run("add ."); git.Run(@"commit -m ""這是自動(dòng)提交的""");
如果需要獲得命令的執(zhí)行結(jié)果,直接使用 Run
方法的返回值即可。
比如下面我貼了 Main
函數(shù)的完整代碼,可以輸出我倉(cāng)庫(kù)的當(dāng)前狀態(tài):
using System; namespace Walterlv.GitDemo { class Program { static void Main(string[] args) { Console.WriteLine("walterlv 的自動(dòng) git 命令"); var git = new CommandRunner("git", @"D:\Developments\Blogs\walterlv.github.io"); var status = git.Run("status"); Console.WriteLine(status); Console.WriteLine("按 Enter 退出程序……"); Console.ReadLine(); } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MVC5 + EF6 + Bootstrap3 (11) 實(shí)現(xiàn)排序、搜索、分頁(yè)
本篇文章主要介紹了MVC5 + EF6 + Bootstrap3 (11) 實(shí)現(xiàn)排序、搜索、分頁(yè),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-12-12.net core 1.0 實(shí)現(xiàn)單點(diǎn)登錄負(fù)載多服務(wù)器
這篇文章主要介紹了.net core 1.0 實(shí)現(xiàn)單點(diǎn)登錄負(fù)載多服務(wù)器的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友可以參考下2016-07-07Entity Framework Core延遲加載(懶加載)用法
這篇文章介紹了Entity Framework Core延遲加載(懶加載)的使用方式,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02完美解決在ModalPopupExtender中使用CalendarExtender時(shí)被層遮擋的問(wèn)題
ASP.NET AJAX Control Toolkit是一組非常不錯(cuò)的基于asp.net的ajax控件,它建立在asp.net 3.0的ScriptManager組件之上,提供了很多非常實(shí)用的效果和功能。2009-11-11ASP.NET使用GridView導(dǎo)出Excel實(shí)現(xiàn)方法
這篇文章主要介紹了ASP.NET使用GridView導(dǎo)出Excel實(shí)現(xiàn)方法,是asp.net操作office文件的一個(gè)典型應(yīng)用,代碼中備有較為詳盡的注釋便于讀者理解,需要的朋友可以參考下2014-11-11