簡體   English   中英

如何在C#win app的App.config中為Key賦值?

[英]How to assign Value to Key in App.config of C# win app?

我在代碼中使用以下字符串:

string AAR_FilePath = "\"C:\\MySQL\\MySQL Server 5.0\\bin\\mysqldump\"";

我不想在我的代碼中刻骨銘心。 所以我需要在我的app.config中使用它,嘗試提供與以下相同的值,

<add key="Path_SqlDump" value="\"C:\\MySQL\\MySQL Server 5.0\\bin\\mysqldump\""></add>

但是由於引號,以上內容給了我錯誤。

我需要的是,我應該能夠分配“ \\” C:\\ MySQL \\ MySQL Server 5.0 \\ bin \\ mysqldump \\“”

到一個字符串。 怎么樣 ?

public string AAR_FilePath = ConfigurationSettings.AppSettings["Path_SqlDump"].ToString();     

public void CreateScript_AAR()
{
    //AAR_FilePath = "\"C:\\MySQL\\MySQL Server 5.0\\bin\\mysqldump\"";
    string commandLine = @"" + AAR_FilePath + " -u" + DbUid + " -p" + DbPwd + " " + DbName + " > " + Path_Backup + FileName_Backup;  
    System.Diagnostics.ProcessStartInfo PSI = new System.Diagnostics.ProcessStartInfo("cmd.exe");
    PSI.RedirectStandardInput = true;
    PSI.RedirectStandardOutput = true;
    PSI.RedirectStandardError = true;
    PSI.UseShellExecute = false;
    System.Diagnostics.Process p = System.Diagnostics.Process.Start(PSI);
    System.IO.StreamWriter SW = p.StandardInput;
    System.IO.StreamReader SR = p.StandardOutput;
    SW.WriteLine(commandLine);
    SW.Close();
}

您無需在app.config中進行所有轉義操作。 那是C#的事情。 只需像在命令提示符下一樣將完整路徑放入app.config中即可。

<add key="Path_SqlDump" value="C:\MySQL\MySQL Server 5.0\bin\mysqldump\" />

John的答案是正確的,您只需要在C#代碼中執行此操作( MySQL Server 5.0就有空格):

 string commandLine = "\"" + AAR_FilePath + "\"" + " -u" 
        + DbUid + " -p" + DbPwd + " " + DbName + " > " 
        + "\"" + Path.Combine(Path_Backup,FileName_Backup) + "\"";

因此,您的命令將如下所示:

“ C:\\ MySQL \\ MySQL Server 5.0 \\ bin \\ mysqldump” -u -sampUid -p sampPassword yourDbName>“ c:\\ archive \\ 2010-05-12.backup”

僅刪除最后一個反斜杠, mysqldumpmysqldump.exe嗎? 對?

<add key="Path_SqlDump" value="C:\MySQL\MySQL Server 5.0\bin\mysqldump" />

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM