C# 如何在序列化xml时保留空标签

来源:这里教程网 时间:2026-02-21 17:28:47 作者:

在 C# 中使用 XmlSerializer 进行 XML 序列化时,如果某个字符串属性为空或为 null,默认情况下该元素会被省略或生成自闭合标签(如 )。如果你希望保留空标签并显示为 的形式,可以通过以下方式实现。

1. 使用 XmlElement 特性指定 IsNullable

通过给属性添加 [XmlElement(IsNullable = true)] 特性,可以让序列化器在值为 null 时保留标签,并输出为

xsi:nil="true"
的格式。虽然这不是纯粹的空标签,但能确保标签存在。

示例:
[XmlElement(IsNullable = true)]
public string Name { get; set; }

序列化结果:

<Name xsi:nil="true" />

注意:这需要包含 xsi 命名空间,且表示“null”而非“空字符串”。

2. 将 null 转为空字符串

如果你希望输出 这样的空标签(内容为空,但标签存在),可以在属性中将 null 显式转为空字符串。

示例:
private string _name;
[XmlElement("Name")]
public string Name
{
    get => _name ?? "";
    set => _name = value;
}

或者在构造函数或赋值时统一处理:

public string Name { get; set; } = "";

这样即使字段为空,也会生成:

<Name></Name>

3. 使用 StringWriter 自定义命名空间

避免默认生成的 xmlns:xsi 和 xmlns:xsd,可以自定义 XmlWriterSettings 并清除命名空间。

示例代码:
var serializer = new XmlSerializer(typeof(Person));
var settings = new XmlWriterSettings
{
    OmitXmlDeclaration = false,
    Indent = true
};
<p>using var stringWriter = new StringWriter();
using var xmlWriter = XmlWriter.Create(stringWriter, settings);
serializer.Serialize(xmlWriter, person);</p><p>string xml = stringWriter.ToString();

结合属性设置为 "" 后,即可输出干净的空标签。

4. 综合建议

若需明确表达“无值”,使用 IsNullable = true,接受
xsi:nil="true"
格式。
若只需保留空标签结构,将属性值设为 string.Empty 或使用默认值 ""。 避免属性为 null 是关键,因为 null 可能导致标签被跳过或变成自闭合。

基本上就这些。只要确保字段不是 null,并合理使用特性,就能在序列化 XML 时保留你想要的空标签格式。

相关推荐