根据项目需求,我们需要记录用户的操作痕迹,当用户下次登录操作同一个文件时,页面显示为用户上一次执行的用户轨迹,我们考虑把用户的历史记录写进xml文件中。

存储的xml数据结构:

XML操作类:

 using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Xml; namespace iImgEnh.UI.AuthenticateImage.AuthImageMethods.Model
{
public class VideoContinuityReadWriteRecord
{
#region 属性
/// <summary>
/// 存放xml内容的文件夹下的文件名
/// </summary>
private string DicFileName = "resources/XMLFile.xml"; #endregion #region 写入xml
/// <summary>
///
/// </summary>
/// <param name="file"></param>
/// <param name="content"></param>
/// <param name="dateTimeStr"></param>
public void WriteDoc(string file,string content,string dateTimeStr)
{
string SavePath = Path.Combine(Directory.GetCurrentDirectory(), "resources"); //判断是否存在文件夹
var DirectoryPath = Path.GetDirectoryName(SavePath); //获取文件夹所在的路径
if (!Directory.Exists(SavePath))
{
Directory.CreateDirectory(SavePath); //创建文件夹
}
XmlDocument doc = new XmlDocument();
if (File.Exists(DicFileName))
{
//如果文件存在 加载XML
doc.Load(DicFileName);
//获得文件的根节点
XmlNodeList xnl = doc.SelectNodes("/Positions/Position/Item");
if (xnl.Count < )
{
CreateDoc(file, content,dateTimeStr);
}
else
{
XmlNode PNode = null;
var isHave = false;
foreach (XmlNode item in xnl)
{
PNode = item.ParentNode;
var name = item.Attributes["Name"].Value;
//var text = item.Attributes["Content"].Value;
if (name == file)
{
isHave = true;
item.Attributes["Content"].Value = content;
item.Attributes["Time"].Value = dateTimeStr;
break;
}
}
if (!isHave)
{
var en = doc.DocumentElement;
XmlElement name1 = doc.CreateElement("Item");
name1.SetAttribute("Name", file);
name1.SetAttribute("Content", content);
name1.SetAttribute("Time", dateTimeStr);
PNode.AppendChild(name1); if (xnl.Count > )
{
PNode.RemoveChild(xnl[]);
} }
}
doc.Save(DicFileName);
}
else
{
CreateDoc(file, content,dateTimeStr);
}
} /// <summary>
/// 读取XML文件
/// </summary>
/// <param name="file"></param>
/// <returns></returns>
public RecordInfo ReadDoc(string file)
{
RecordInfo info = new RecordInfo();
XmlDocument doc = new XmlDocument();
if (File.Exists(DicFileName))
{
//如果文件存在 加载XML
doc.Load(DicFileName);
//获得文件的根节点
XmlNodeList xnl = doc.SelectNodes("/Positions/Position/Item");
if (xnl.Count > )
{
foreach (XmlNode item in xnl)
{
if (item.Attributes["Name"].Value == file)
{
info.Position = item.Attributes["Content"].Value;
info.Time = item.Attributes["Time"].Value;
}
}
}
}
return info;
} /// <summary>
/// 创建XML文件
/// </summary>
/// <param name="file"></param>
/// <param name="content"></param>
/// <param name="dateTimeStr"></param>
private void CreateDoc(string file, string content,string dateTimeStr)
{
XmlDocument doc = new XmlDocument();
//3、创建第一个行描述信息,并且添加到doc文档中
XmlDeclaration dec = doc.CreateXmlDeclaration("1.0", "utf-8", null);
doc.AppendChild(dec);
//4、创建根节点
XmlElement books = doc.CreateElement("Positions");
//将根节点添加到文档中
doc.AppendChild(books); //5、给根节点Books创建子节点
XmlElement book1 = doc.CreateElement("Position");
//将book添加到根节点
books.AppendChild(book1);
//6、给Book1添加子节点
XmlElement name1 = doc.CreateElement("Item");
name1.SetAttribute("Name", file);
name1.SetAttribute("Content", content);
name1.SetAttribute("Time", dateTimeStr);
book1.AppendChild(name1); doc.Save(DicFileName);
} #endregion
} public class RecordInfo
{
/// <summary>
/// 位置
/// </summary>
public string Position { get; set; } /// <summary>
/// 时间格式
/// </summary>
public string Time { get; set; }
}
}

c# 操作xml文件(读写)的更多相关文章

  1. 实现动态的XML文件读写操作

    实现动态的XML文件读写操作(依然带干货) 前言 最近由于项目需求,需要读写操作XML文件,并且存储的XML文件格式会随着导入的数据不同而随时改变(当然导入的数据还是有一定约束的),这样我们要预先定义 ...

  2. 实现动态的XML文件读写操作(依然带干货)

    前言 最近由于项目需求,需要读写操作XML文件,并且存储的XML文件格式会随着导入的数据不同而随时改变(当然导入的数据还是有一定约束的),这样我们要预先定义好XML文件的格式就不太现实了,如何实现不管 ...

  3. Qt之QDomDocument操作xml文件-模拟ini文件存储

    一.背景 不得不说Qt是一个很强大的类库,不管是做项目还是做产品,Qt自身封装的东西就已经非常全面了,我们今天的这篇文章就是模拟了Qt读写ini文件的一个操作,当然是由于一些外力原因,我们决定自己来完 ...

  4. QXmlStreamReader/QXmlStreamWriter实现Qt下xml文件读写

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QXmlStreamReader/QXmlStreamWriter实现Qt下xml文件读写   ...

  5. QSettings配置读写-win注册表操作-ini文件读写

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QSettings配置读写-win注册表操作-ini文件读写     本文地址:http:// ...

  6. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  7. Java操作XML文件 dom4j 篇

    在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它系统的数据交互.今天就来讲一下Java 中使用dom4j来操作XML文件. 我们需要引入的包: //文件包 import java.io. ...

  8. PHP操作XML文件学习笔记

    原文:PHP操作XML文件学习笔记 XML文件属于标签语言,可以通过自定义标签存储数据,其主要作用也是作为存储数据. 对于XML的操作包括遍历,生成,修改,删除等其他类似的操作.PHP对于XML的操作 ...

  9. JAVA中通过Jaxp操作XML文件基础

    Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...

  10. WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)

    WebAPI调用笔记   前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...

随机推荐

  1. mysql 生成随机数rand()

    mysql> select rand(); +--------------------+ | rand() | +--------------------+ | 0.99134733527092 ...

  2. 通过phoenix导入数据到hbase出错记录

    解决方法1 错误如下 -- ::, [hconnection-0x7b9e01aa-shared--pool11069-t114734] WARN org.apache.hadoop.hbase.ip ...

  3. 什么是TCP粘包?怎么解决这个问题

    在socket网络编程中,都是端到端通信,由客户端端口+服务端端口+客户端IP+服务端IP+传输协议组成的五元组可以明确的标识一条连接.在TCP的socket编程中,发送端和接收端都有成对的socke ...

  4. 生成一个字母数字组合的n位随机码、随机数、随机字符串

    package com.cms.util; /** * 生成一个字母数字组合的n位随机码 * @author abc * */ public class CodeUtil { // private f ...

  5. 273道题目;更新到java题目里面 (已迁移到其他类目下面,存储)

    1. Java 基础 1.JDK 和 JRE 有什么区别? 2. == 和 equals 的区别是什么? 3. 两个对象的 hashCode() 相同,则 equals() 也一定为 true,对吗? ...

  6. [源码分析]LinkedHashMap

    一个键有序的 HashMap   可以将 LinkedHashMap 理解为 LinkList + HashMap,所以研究LinkedHashMap之前要先看HashMap代码.这里不再赘述.其实L ...

  7. MySQL Group By 实例讲解(二)

    mysql group by使用方法实例讲解 MySQL中GROUP BY语句用于对某个或某些字段查询分组,并返回这个字段重复记录的第一条,也就是每个小组(无排序)里面的第一条. 本文章通过实例向大家 ...

  8. layui的layer.open()方法查看缩略图 原图缩放

    写在前面 需求是页面上的图片缩略图, 鼠标悬浮时显示原图片, 并按比例缩放. 操作步骤 官方文档 点击跳转 关键属性 1. type: 设置type=1, 以页面的形式展示图片 2.  content ...

  9. Angularjs 标签使用整理

    持续更新..... 一.select setmealList为接收到的集合数据,sname 是要显示的字段,Object属性 套餐类型:<select style="width: 15 ...

  10. 数据分析入门——pandas之合并函数merge

    merge有点类似SQL中的join,可以将不同数据集按照某些字段进行合并,得到新的数据集  1.参数一览表: 2.一对一连接:默认情况下,会按照相同字段的进行连接 例如有相同字段emp的两个df,m ...