c# - 将 XML 转换为 JSON 到 C# 对象

标签 c# json xml

作为动态文档处理器应用程序的一部分,我们必须将数千个文档从 XML 迁移到 Json。这是我的方法。

我有这个 Xml

<?xml version="1.0"?>
    <syscur_historial_schema>
        <strtipoobj>OM_SECCION</strtipoobj>
        <strnombreobj>_1_Seccion_IDENTIFICACION_DEL_PACIENTE</strnombreobj>
        <numobj>0.00</numobj>
        <txtpropsobj/>
        <txtprostit><![CDATA[BackColor = 14171687,BorderStyle = 0,FontBold = .F.,FontItalic = .F.,FontName = "Tahoma",FontSize = 9,FontUnderline = .F.,ForeColor = 0,AutoSize = .F.,BackStyle = 1,LineColor = 14171687, TitleWidth=100, CAPTION="IDENTIFICACION DEL PACIENTE"]]>
        </txtprostit>
        <strencabezado>IDENTIFICACION DEL PACIENTE</strencabezado>
    </syscur_historial_schema>

我将其转换为 JSon:

enter image description here

然后我需要将该 JSon 反序列化到这个 C# 类中:

public class syscur_historial_schema
{
    public string strtipoobj { get; set; }
    public string strnombreobj { get; set; }
    public string numobj { get; set; }
    public string txtpropsobj { get; set; }
    public string txtprostit { get; set; }
    public string strencabezado { get; set; }
}

这是我的转换器:

public class ConvertXmlToJson
{
    /// <summary>
    /// Convierte un archivo con formato XML en fornato JSon 
    /// usando JsonConvert.SerializeXmlNode(doc)
    /// </summary>
    /// <param name="xmlPath"></param>
    /// <returns></returns>
    public static string XmlToJsonSerializeXmlNode<T>(string xmlPath, string nodeName, bool cleanString)
    {
        string justPath = Path.GetDirectoryName(xmlPath);
        string json = Path.Combine(justPath, $"{Path.GetFileNameWithoutExtension(xmlPath)}.json");
        XmlDocument doc = new XmlDocument();

        if (cleanString)
            doc.LoadXml(CleanRepeatedSpaces(File.ReadAllText(xmlPath)));
        else
            doc.LoadXml(File.ReadAllText(xmlPath));

        XmlNodeList nodes = GetNode(doc, nodeName);
        List<T> lista = new List<T>();
        foreach (XmlNode node in nodes)
        {
            string jSonNode = JsonConvert.SerializeXmlNode(node);
            T obj = JsonConvert.DeserializeObject<T>(jSonNode);
            lista.Add(obj);
        }
        File.WriteAllText(json, JsonConvert.SerializeObject(lista));
        return json;
    }

    public static XmlNodeList GetNode(XmlDocument doc, string nodeName)
    {
        XmlNodeList nodes = doc.GetElementsByTagName(nodeName);
        return nodes;
    }
}    

还有这个测试方法

[TestMethod]
public void Tools_ConvertXmlToJson_Tests()
{
    string path = "D:\\MyXmlPath\\";
    string xml = Path.Combine(path, "MyXmlFile.hist");
    string jsonFile = ConvertXmlToJson.XmlToJsonSerializeXmlNode<syscur_historial_schema>(xml, "syscur_historial_schema",true);
    Assert.AreEqual(true, File.Exists(jsonFile));
    List<syscur_historial_schema> jsonObject = JsonConvert.DeserializeObject<List<syscur_historial_schema>>(File.ReadAllText(jsonFile));
}

现在我的问题是我的反序列化对象总是在每个属性上返回 null,我认为问题出在 CDATA 节点上。

问题

1-我做错了什么?

2- 如何将 xml CDATA 转换为 Json 字符串?

最佳答案

使您的 syscur_historial_schema 类像这样序列化:

[Serializeable]     
public class syscur_historial_schema
{
 public string strtipoobj { get; set; }
 public string strnombreobj { get; set; }
 public string numobj { get; set; }
 public string txtpropsobj { get; set; }
 public string txtprostit { get; set; }
 public string strencabezado { get; set; }
}

然后将 xml 反序列化到类中,如下所示:

XmlSerializer serializer = new XmlSerializer(typeof(syscur_historial_schema));

StreamReader reader = new StreamReader(xmlPath);
var schema = (syscur_historial_schema)serializer.Deserialize(reader);
reader.Close();

然后将 schema 转换为 json,如下所示:

 string json = JsonConverter.SerializeObject(schema);

在将 xml 字符串转换为类对象之前,您不必将其转换为 xml 文档。直接将xml字符串反序列化到类对象中。

关于c# - 将 XML 转换为 JSON 到 C# 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51197869/

相关文章:

c# - WPF 选项卡控件防止选项卡更改

c# - LinqToSql 预编译查询有什么好处?

json - 使用 jq 如何用其他东西替换键的名称

ruby-on-rails - 有没有办法在 Ruby on Rails 中保持 POSTed XML 的完整性?

c# - 对包含字母和破折号的字符串进行排序时出现意外行为

c# - Entity Framework linq查询中IEnumerable.Contains()的解决方案

c++ - 协议(protocol) buffer3 和 json

java - 获取详细的 json 响应(没有 id 引用,始终是实例)

xml - 为 uri 编码和绝对 Windows 路径

c# - 如何使用 LINQ 解析 XML header 和嵌套部分