Jim Mischel的评论中的link指出,Win32 API为此提供了一个函数。我建议使用它来保持一致性。以下是一个示例(来自PInvoke)。
static string[] SplitArgs(string unsplitArgumentLine)
{
int numberOfArgs;
IntPtr ptrToSplitArgs;
string[] splitArgs;
ptrToSplitArgs = CommandLineToArgvW(unsplitArgumentLine, out numberOfArgs);
if (ptrToSplitArgs == IntPtr.Zero)
throw new ArgumentException("Unable to split argument.",
new Win32Exception());
try
{
splitArgs = new string[numberOfArgs];
for (int i = 0; i < numberOfArgs; i++)
splitArgs[i] = Marshal.PtrToStringUni(
Marshal.ReadIntPtr(ptrToSplitArgs, i * IntPtr.Size));
return splitArgs;
}
finally
{
LocalFree(ptrToSplitArgs);
}
}
[DllImport("shell32.dll", SetLastError = true)]
static extern IntPtr CommandLineToArgvW(
[MarshalAs(UnmanagedType.LPWStr)] string lpCmdLine,
out int pNumArgs);
[DllImport("kernel32.dll")]
static extern IntPtr LocalFree(IntPtr hMem);
如果你想快速和肮脏的,不灵活的,脆弱的正则表达式的解决方案,你可以做这样的事情:
var rex = new Regex(@"("".*?""|[^ ""]+)+");
string test = "CALL \"C:\\My File Name With Space\" /P1 P1Value /P1 P2Value";
var array = rex.Matches(test).OfType<Match>().Select(m => m.Groups[0]).ToArray();
是不是你在Main()中将字符串数组作为命令行参数? –
不,我正在解析文件夹中的批处理文件。 – ChadD
我不会使用正则表达式来处理这个问题。命令行中有太多特殊情况。你最好使用http://stackoverflow.com/questions/491595/best-way-to-parse-command-line-arguments-in-c?rq=1的建议之一,或者只是写你的自己的(这可能需要几个小时)。 –