我有一个字符串,其中包含两组双引号,如下所示:
string ns = @"<tns:Event xmlns:tns=""http://sbr.gov.au/comn/event.02.data"">";
我需要用单引号替换命名空间周围的两组双双引号,但是我正在努力寻找方法。我敢肯定这很容易,但是我对C#还是很陌生。
谢谢。
在我的广泛问题上再扩大一点。下面是我在SSIS脚本组件中使用的代码:
string xml = Row.RejectReason.ToString();
XDocument xDoc = XDocument.Parse(xml);
XNamespace tns = "http://sbr.gov.au/comn/event.02.data";
var eventItems = xDoc.Element(tns + "Event").Element(tns + "EventItems").Elements(tns + "EventItem");
foreach (var eventItem in eventItems)
{
Row.RejectReason = eventItem.Element(tns + "Short.Description").Value;
}
由于XML中名称空间周围的双引号引起来,XML的解析失败。该XML片段来自CSV文件。
答案 0 :(得分:2)
在字符串前使用@时,必须输入“”作为“。 最后,ns继续
<tns:Event xmlns:tns="http://sbr.gov.au/comn/event.02.data">
或者您可以这样做:
string ns = "<tns:Event xmlns:tns=\"http://sbr.gov.au/comn/event.02.data\">";
但没什么
答案 1 :(得分:0)
您可以使用字符串的 import Api_Test_Scripts.RunnerSub;
public class mainRunner {
public static void main(String[] args) throws InterruptedException {
RunnerSub obj= new RunnerSub();
obj.starttest();
obj.runner();
obj.endReport();
}
}
方法:
Replace()
或
ns = ns.Replace('"', '\'');
答案 2 :(得分:0)
您可以尝试使用正则表达式。像
var checkDoubleQuotes = @"""";
ns = Regex.Replace(ns, checkDoubleQuotes, "\"");
答案 3 :(得分:0)
您可以使用转义字符作为引号。请参阅此mdn文章: Link
答案 4 :(得分:0)
您可以用\'替换单引号“”
Regex.Replace(ns, @"""", "\'");
或将\“替换为双引号
Regex.Replace(ns, @"""", "\"");