0

我有一个 xml 字符串,里面有不同的记录,我想在每条记录中提取 id。这是xml的示例:

<UploadsInformation >
    <Record>
        <TaskGUID>48A583CA-A532-419A-9CDB-292764CEC541</TaskGUID>
    </Record>
    <Record>
        <TaskGUID>ED6BA682-2BB2-4ADF-8355-9C605E16E088</TaskGUID>
    </Record>
    <Record>
        <TaskGUID>D20D7042-FC5B-4CF7-9496-D2D9DB68CF52</TaskGUID>
    </Record>
    <Record>
        <TaskGUID>F5DB10C5-D517-4CDA-8AAA-4E3F50B5FF3C</TaskGUID>
    </Record>
</UploadsInformation>

这就是我作为字符串来提取我需要的信息但不确定它是否正确,因为当我调试时,字符串似乎是 xml 文件,而不仅仅是指定的 guid。

string data = new XDocument(new XElement("Record", 
    uploads.Select(guid => new XElement("TaskGUID", guid.ToString()))))
    .ToString();

上传是:List<Guid?> uploads

4

3 回答 3

2

如果我正确理解您的问题,您想从源 XML 中提取 Guid,您指出它是一个字符串。

您可以使用以下命令从字符串创建 XDocument:

XDocument doc = XDocument.Parse(xmlString);

XNamespace ns = "http://schemas.acatar.com/2013/03/Malt.Models";

List<string> uploads = doc.Descendants(ns + "TaskGUID")
                       .Select(x => x.Value).ToList();

string uploadString = String.Join(",", uploads);

我之所以使用XNamespace它是因为在 XML 中定义了一个名称空间(实际上是两个),除非您在元素名称前加上正确的名称,否则您不会得到任何结果。

您也许可以将最后两个步骤合并为一行,但我不能 100% 确定。

上面的代码已经用您的示例进行了测试,并为 生成以下值uploadString

48A583CA-A532-419A-9CDB-292764CEC541,ED6BA682-2BB2-4ADF-8355-9C605E16E088,D20D7042-FC5B-4CF7-9496-D2D9DB68CF52,F5DB10C5-D517-4CDA53FFBAAA-4E3F5C

但是,如果您要遍历结果并将每个结果单独传递给存储过程,我将跳过String.Join并仅遍历列表:

foreach (string id in uploads)
{

    // Do your stored procedure call for each Guid.
}

添加以回应评论

在您评论中的情况下,如果您有一个想要获取其值的列表,您基本上会做同样的事情,但是您需要检查空值并(可能)在传递之前将 Guid 转换为字符串它进入存储过程:

foreach (Guid? g in uploads)
{

    if (g != null)
    {

        string newGuid = g.ToString();

        // do your data access stuff here
    }
}
于 2013-07-01T09:46:48.257 回答
2

您不能使用元素的本地名称,因为您已声明命名空间。因此,您应该使用命名空间来提供名称:

XNamespace ns = "http://schemas.acatar.com/2013/03/Malt.Models";
var guids = from r in xdoc.Root.Elements(ns + "Record")
            select Guid.Parse((string)r.Element(ns + "TaskGUID"));

或者在不指定元素名称的情况下查询您的 xml:

var guids = xdoc.Root.Elements()
                .Select(r => Guid.Parse((string)r.Elements().Single()));
于 2013-07-01T09:47:00.240 回答
0

我认为这要么是您所追求的,要么可能会阐明前进的方向:

string xml = "";  // XML data here

XDocument doc = XDocument.Parse(xml);

List<Guid> guids = doc.Descendants("TaskGUID")
                         .Select(g => new Guid(g.Value))
                         .ToList();
于 2013-07-01T09:41:56.727 回答