簡體   English   中英

C#從XML刪除字符串

[英]c# Remove string from XML

我有一個具有幾個屬性和值的xml,如下所示:

<z:row ID="1"
       Author="2;#Bruce, Banner"
       Editor="1;#Bruce, Banner"
       FileRef="1;#Reports/Pipeline Tracker Report.xltm" 
       FileDirRef="1;#Reports" 
       Last_x0020_Modified="1;#2014-04-04 12:05:56" 
       Created_x0020_Date="1;#2014-04-04 11:36:21" 
       File_x0020_Size="1;#311815" 
/>

如何從“到#號之后刪除字符串?

原版的

'Author =“ 2; #Bruce,Banner”“

轉換

'Author =“ Bruce,橫幅廣告”

看看是否有幫助。

private string FilterValue(string input)
{
    // If the string does not contain #, return value
    if (!input.Contains("#"))
        return input;

    // # does exist in the string so 
    // 1) find its location
    // 2) Read everything from that point to the end of the string
    // 3) Return the SubString value
    var index = input.IndexOf("#", StringComparison.Ordinal) + 1;
    return input.Substring(index, input.Length - index);
}

像這樣嗎?

// same logic then M Patel.
// This one will fit only if you have three items to remove (one digit, one semi-colon and one sharp).
// use M Patel solution
string CleanElement(string elem)
{
    return elem.Substring(3, elem.Length - 3);
}

或像這樣:

// slower I guess but still a solution
string CleanElement(string elem)
{
     string[] strs = elem.Split('#');
     strs[0] = "";
     return string.Join("", strs);
}

您可以使用string.Substringstring.IndexOf方法

string value= node.Attributes["Author"].Value;
value=value.Substring(0, value.IndexOf('#'));

我希望這是您正在尋找的假設您已經從xml文檔中讀取了您的節點

如果您不熟悉C#中的XML,我建議您看一下以下msdn鏈接https://msdn.microsoft.com/zh-cn/library/cc189056(v=vs.95).aspx

您可以使用regex進行模式搜索,並使用regEx.Replace()方法。 正則表達式可能類似於“ \\ d;#”。

如果輸入為2,它將正常工作; #Bruce,橫幅!

 string value= node.Attributes["Author"].Value;
 var op = value.Split('#');
 string name = op[1];

如果期望其他#,

string value1 = value.Substring(3, value.Length - 3);

您可以使用一個簡單的正則表達式:

string s = @"<z:row ID=""1""
   Author=""2;#Bruce, Banner""
   Editor=""1;#Bruce, Banner""
   FileRef=""1;#Reports/Pipeline Tracker Report.xltm"" 
   FileDirRef=""1;#Reports"" 
   Last_x0020_Modified=""1;#2014-04-04 12:05:56"" 
   Created_x0020_Date=""1;#2014-04-04 11:36:21"" 
   File_x0020_Size=""1;#311815""
    />";

string result = Regex.Replace(s,"\"([0-9];#)","");

暫無
暫無

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

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