C#/.NET使用git命令行來操作git倉庫的方法示例
我們可以在命令行中操作 git,但是作為一名程序員,如果在大量重復(fù)的時候還手動敲命令行,那就太笨了。
本文介紹使用 C# 編寫一個 .NET 程序來自動化地使用 git 命令行來操作 git 倉庫。
這是一篇很基礎(chǔ)的入門文章。
最簡單的運行 git 命令的代碼
在 .NET 中,運行一個命令只需要使用 Process.Start 開啟一個子進程就好了。于是要運行一個 git 命令,我們其實只需要這句足以:
Process.Start("git", "status");
當(dāng)然,直接能簡寫成 git 是因為 git.exe 在我的環(huán)境變量里面,一般開發(fā)者在安裝 Git 客戶端的時候,都會自動將此命令加入到環(huán)境變量。如果沒有,你需要使用完整路徑 C:\Program Files\Git\mingw64\bin\git.exe 只是每個人的路徑可能不同,所以這是不靠譜的。
允許獲得命令的輸出
對于上節(jié)中寫的 Process.Start ,你一眼就能看出來這是完全沒有用的代碼。因為 git status 命令只是獲得倉庫當(dāng)前的狀態(tài),這個命令完全不影響倉庫,只是為了看狀態(tài)的。
所以,命令最好要能夠獲得輸出。
而要獲得輸出,你需要使用 ProcessStartInfo 來指定如何啟動一個進程。
var info = new ProcessStartInfo(ExecutablePath, arguments)
{
CreateNoWindow = true,
RedirectStandardOutput = true,
UseShellExecute = false,
WorkingDirectory = WorkingDirectory,
};
需要設(shè)置至少這四個屬性:
CreateNoWindow表示不要為這個命令單獨創(chuàng)建一個控制臺窗口
實際上如果使用此代碼的程序也是一個控制臺程序,這句是沒有必要的,因為子進程會共用父進程的控制臺窗口;但是對于 GUI 程序來說,這句還是很重要的,這可以避免在執(zhí)行命令的過程中意外彈出一個黑色的控制臺窗口出來。
RedirectStandardOutput進行輸出的重定向
這是一定要設(shè)置為 true 的屬性,因為我們希望拿到命令的輸出結(jié)果。
WorkingDirectory設(shè)置工作路徑
本來這是一個可選設(shè)置,不過對于 git 命令來說,一般都是對一個已有的 git 倉庫進行操作,所以當(dāng)然要指定一個合理的 git 倉庫了。
UseShellExecute設(shè)置為false表示不要使用ShellExecute函數(shù)創(chuàng)建進程
此屬性的詳細(xì)說明,
UseShellExecute 的默認(rèn)值是 true。
如果有以下需求,那么建議設(shè)置此值為 false:
- 需要明確執(zhí)行一個已知的程序
- 需要重定向輸入和輸出
如果你有以下需求,那么建議設(shè)置此值為 true 或者保持默認(rèn):
- 需要打開文檔、媒體、網(wǎng)頁文件等
- 需要打開 Url
- 需要打開腳本執(zhí)行
- 需要打開計算機上環(huán)境變量中路徑中的程序
這里我們必須指定為 false ,因為要重定向輸出的話,這是唯一有效值。順便一提,此屬性如果不設(shè)置,默認(rèn)值是 true 。
CommandRunner
為了方便起見,我將全部運行一個命令的代碼封裝到了一個 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();
}
}
}
測試與結(jié)果
以上 CommandRunner 命令的使用非常簡單, new 出來之后,得到一個可以用來執(zhí)行命令的實例,然后每次執(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 ""這是自動提交的""");
如果需要獲得命令的執(zhí)行結(jié)果,直接使用 Run 方法的返回值即可。
比如下面我貼了 Main 函數(shù)的完整代碼,可以輸出我倉庫的當(dāng)前狀態(tài):
using System;
namespace Walterlv.GitDemo
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("walterlv 的自動 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();
}
}
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
理解ASP.NET Core 中間件(Middleware)
這篇文章主要介紹了ASP.NET Core 中間件(Middleware),中間件是一種裝配到應(yīng)用管道以處理請求和響應(yīng)的軟件。文中講解相關(guān)知識非常詳細(xì),感興趣的朋友可以一起來看一看2021-09-09
asp.net 獲取目錄下的文件數(shù)和文件夾數(shù)
遍歷一個文件夾中的文件,需要用到DirectoryInfo類中的一個重要的方法GetFileSystemInfos(),此方法返回指定的是與搜索條件相匹配的文件和子目錄的強類型 FileSystemInfo對象的數(shù)組。2010-07-07
ASP.NET Core使用AutoMapper實現(xiàn)實體映射
本文詳細(xì)講解了ASP.NET Core使用AutoMapper實現(xiàn)實體映射的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
asp.net實現(xiàn)上傳文件顯示本地絕對路徑的實例代碼
asp.net實現(xiàn)上傳圖片顯示本地絕對路徑圖片,其實這個還是得用<DIV></DIV>去顯示圖片會更好一點!用js實現(xiàn)圖片的比例壓縮讓圖片一樣能夠很清楚!下面把代碼貼出來2013-07-07

