-
通过XmlNodeType.ProcessingInstruction属性获取到InfoPath XML文件头信息
通过InfoPath Form生成的XML文件在文件开头的地方都会附加上一段特定的信息,用于标识该XML文件是由什么版本的InfoPath Form生成的,所对应的XSN模板的存放位置等信息,如下图所示:
那么我们在使用XDocument.Load()方法加载该XML文件之后,如何获取到文件头中相关的节点信息呢?如mso-infoPathSolution。
在XmlNodeType类型中,ProcessingInstruction申明了类似于“<?pi test?>” 的节点,我们可以通过该属性来筛选XML的节点,下面的函数用于找出InfoPath Form XML文件中的文件头信息,并将mso-infoPathSolution节点中的href属性值做修改,将XSN模板的位置修改成别的服务器中对应的位置。
1 /// <summary>
2 /// Replace the reference url with the target server name for each InfoPath xml file.
3 /// </summary>
4 /// <param name="path"></param>
5 /// <param name="targetServer"></param>
6 public static void ReplaceReferenceUrl(string path, string targetServer)
7 {
8 const string pattern = "href=\"http://.*?/"; // Regular expression used for replacing the reference url in the XML files.
9 DirectoryInfo info = new DirectoryInfo(path);
10 FileInfo[] files = info.GetFiles("*.xml");
11
12 foreach (FileInfo file in files)
13 {
14 XDocument document = XDocument.Load(file.FullName);
15 List<XNode> list = document.Nodes().Where(t => t.NodeType == System.Xml.XmlNodeType.ProcessingInstruction).ToList<XNode>();
16 if (list != null)
17 {
18 foreach (XNode item in list)
19 {
20 XProcessingInstruction tmp = item as XProcessingInstruction;
21 if (tmp.Target.Equals("mso-infoPathSolution"))
22 {
23 Regex reg = new Regex(pattern);
24 tmp.Data = reg.Replace(tmp.Data, "href=\"http://" + targetServer + "/");
25 document.Save(file.FullName);
26 break;
27 }
28 }
29 }
30 }
31
32 DirectoryInfo[] direcotries = info.GetDirectories();
33 foreach (DirectoryInfo directory in direcotries)
34 {
35 ReplaceReferenceUrl(directory.FullName, targetServer);
36 }
2 /// Replace the reference url with the target server name for each InfoPath xml file.
3 /// </summary>
4 /// <param name="path"></param>
5 /// <param name="targetServer"></param>
6 public static void ReplaceReferenceUrl(string path, string targetServer)
7 {
8 const string pattern = "href=\"http://.*?/"; // Regular expression used for replacing the reference url in the XML files.
9 DirectoryInfo info = new DirectoryInfo(path);
10 FileInfo[] files = info.GetFiles("*.xml");
11
12 foreach (FileInfo file in files)
13 {
14 XDocument document = XDocument.Load(file.FullName);
15 List<XNode> list = document.Nodes().Where(t => t.NodeType == System.Xml.XmlNodeType.ProcessingInstruction).ToList<XNode>();
16 if (list != null)
17 {
18 foreach (XNode item in list)
19 {
20 XProcessingInstruction tmp = item as XProcessingInstruction;
21 if (tmp.Target.Equals("mso-infoPathSolution"))
22 {
23 Regex reg = new Regex(pattern);
24 tmp.Data = reg.Replace(tmp.Data, "href=\"http://" + targetServer + "/");
25 document.Save(file.FullName);
26 break;
27 }
28 }
29 }
30 }
31
32 DirectoryInfo[] direcotries = info.GetDirectories();
33 foreach (DirectoryInfo directory in direcotries)
34 {
35 ReplaceReferenceUrl(directory.FullName, targetServer);
36 }
首先通过拉姆达表达式 找出所有ProcessingInstruction类型的节点,然后使用正则表达式替换href属性的值(注意只替换了其中ServerName的部分)。后面的递归调用表示该方法允许修改指定目录中所有的XML文件。
在SharePoint中,很多地方使用InfoPath Form来收集XML数据文件,当需要批量上传InfoPath XML文件时,修改文件头信息是必要的步骤,通过上面的函数,我们可以很简单地实现这一点!记录一下,以方便日后查阅。
出处:https://www.cnblogs.com/jaxu/archive/2011/10/04/2198752.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数