xml文件读写
写入
XDocument document = new XDocument();
XElement root = new XElement(Root);
foreach(var columnDto in columns)
{
XElement column = new XElement(Column);
column.SetElementValue(nameof(columnDto.Name), columnDto.Name);
column.SetElementValue(nameof(columnDto.AliasName), columnDto.AliasName);
column.SetElementValue(nameof(columnDto.IsCanNotModify), columnDto.IsCanNotModify);
root.Add(column);
}
root.Save(filePath);
读取
List<ColumnDto> columns = new List<ColumnDto>();
//将XML文件加载进来
XDocument document = XDocument.Load(filePath);
//获取到XML的根元素进行操作
XElement root = document.Root;
//获取根元素下的所有子元素
IEnumerable<XElement> enumerable = root.Elements();
foreach (XElement column in enumerable)
{
ColumnDto columnDto = new ColumnDto();
foreach (XElement property in column.Elements())
{
if (property.Name == nameof(columnDto.Name))
{
columnDto.Name = property.Value;
}
else if(property.Name == nameof(columnDto.AliasName))
{
columnDto.AliasName = property.Value;
}
else if (property.Name == nameof(columnDto.IsCanNotModify))
{
columnDto.IsCanNotModify = bool.Parse(property.Value);
}
//Console.WriteLine($"{property.Name}:{property.Value}");
}
columns.Add(columnDto);
//Console.WriteLine(column.Attribute("id").Value);
}
return columns;
ColumnDto
public class ColumnDto
{
public string Name { get; set; }
public string AliasName { get; set; }
public bool IsCanNotModify { get; set; }
}
获得结果
<?xml version="1.0" encoding="utf-8"?>
<Root>
<Column>
<Name>Time</Name>
<AliasName>时间</AliasName>
<IsCanNotModify>false</IsCanNotModify>
</Column>
</Root>
示例代码
学习技术最好的文档就是【官方文档】,没有之一。
还有学习资料【Microsoft Learn】、【CSharp Learn】、【My Note】。
如果,你认为阅读这篇博客让你有些收获,不妨点击一下右下角的【推荐】按钮。
如果,你希望更容易地发现我的新博客,不妨点击一下【关注】。