(3)TXT转为XML
- <?xml version="1.0" encoding="utf-8"?>
- <bocb2e>
- <head />
- <trans>
- <trn-b2e0035-rq>
- <b2e0035-rq>
- <ibknum>11111</ibknum>
- <actacn>111</actacn>
- <type>2001</type>
- <datescope>
- <from>20150320</from>
- <to>20150320</to>
- </datescope>
- <amountscope>
- <from>0</from>
- <to>100</to>
- </amountscope>
- <begnum />
- <recnum />
- <direction>0</direction>
- </b2e0035-rq>
- </trn-b2e0035-rq>
- </trans>
- </bocb2e>
该段是一个XML代码,现在我们要做的是将以下的TXT文件转化为上述格式,TXT格式如下:
ibknum|actacnc|type |datescope_from|datescope_to|direction
1111 |111 |2002|20020214 |20020214 |0
首先,有两个路径,分别是读取路径和保存路径,downfolder和savefolder。我们的txt是保存在ftp服务器上的,这一点我们下一篇文章会讲述,怎么从ftp上下载一个文件。
现在我们直接从savefolder开始,也就是已经下载好的文件夹。
下面的方法现将txt转化为一个datatable,然后转换为list
- private DataTable B2eRqTxtToDt(string txtpath,string strErrMsg="",string encodingCode = "GB2312", string strSplit = "|")
- {if(txtpath.IndexOf("ftp")>=){
- //创建ftp请求信息
- var ftpRequest = new FtpClient(ftpUser, ftpPassword);
- string savePath = GetDataFileSavePath();
- ftpRequest.DownloadFile(savePath, txtpath, true);
- }
- //read first line
- StreamReader objReader = new StreamReader(savePath, Encoding.GetEncoding(encodingCode));
- string sLine = objReader.ReadLine();
- objReader.Close();
- //all column's header
- string[] ColumnHeaders = sLine.ToString().Trim().Split(strSplit).Select(q => q.Trim()).ToArray();
- // to datatable
- //直接取datatable
- DataTable dt = TxtService.TextFileLoader(savePath, "txt", ColumnHeaders, out strErrMsg, encodingCode, strSplit);
- return dt;
- }
- private List<RqList> B2eRqDtToLs(DataTable dt)
- {
- var date = DateTime.Now.AddDays(-).Date;
- List<RqList> rqlist = new List<RqList>();
- for (int i = ; i < dt.Rows.Count; i++)
- {
- RqList rqls = new RqList();
- b2e0035_rq b2erq = new b2e0035_rq();
- b2erq.ibknum = dt.Rows[i][].ToString();
- b2erq.actacn = dt.Rows[i][].ToString();
- b2erq.type = "";
- b2erq.datescope_from = date.Date;
- b2erq.datescope_to = date.Date;
- b2erq.amountscope_from = null;
- b2erq.amountscope_to = null;
- b2erq.begnum = null;
- b2erq.recnum = null;
- b2erq.direction = "";
- #region //这几句是读取txt文件中的.另外还有string转换为DateTime类型的。
- b2erq.type = dt.Rows[i][].ToString();
- b2erq.datescope_from = DateTime.Parse(dt.Rows[i][].ToString());
- #endregion
- rqls.head = null;
- rqls.b2e0035_rq = b2erq;
- rqlist.Add(rqls);
- }
- return rqlist;
- }
将txt转化为list之后,借助写XML方法可以将其写入XML中。
- public void WriteToXML(string ibknum,string actacn,string path)
- {
- //string path = @"C:\Users\zuomeiyan\XMLRequest.xml";
- XmlTextWriter xtw = new XmlTextWriter(path, UTF8Encoding.UTF8);
- var date = DateTime.Now.AddDays(-).Date;
- try
- {
- xtw.Formatting = Formatting.Indented;
- xtw.WriteStartDocument();
- xtw.WriteStartElement("bocb2e");
- ////head
- xtw.WriteStartElement("head");
- xtw.WriteEndElement();
- //交易数据块
- xtw.WriteStartElement("trans");
- xtw.WriteStartElement("trn-b2e0035-rq");
- xtw.WriteStartElement("b2e0035-rq");
- xtw.WriteElementString("ibknum", ibknum);
- xtw.WriteElementString("actacn", actacn);
- xtw.WriteElementString("type", "");
- xtw.WriteStartElement("datescope");
- xtw.WriteElementString("from", date.Date.ToString("yyyyMMdd"));
- xtw.WriteElementString("to", date.Date.ToString("yyyyMMdd"));
- xtw.WriteEndElement();
- xtw.WriteStartElement("amountscope");
- xtw.WriteElementString("from", null);
- xtw.WriteElementString("to", null);
- xtw.WriteEndElement();
- xtw.WriteElementString("begnum", null);
- xtw.WriteElementString("recnum", null);
- xtw.WriteElementString("direction", "");
- xtw.WriteEndElement();
- xtw.WriteEndElement();
- xtw.WriteEndElement();
- xtw.WriteEndElement();
- xtw.WriteEndDocument();
- }
- catch { }
- finally
- {
- xtw.Flush();
- xtw.Close();
- xtw.Dispose();
- }
- }
这样我们就完成了将一个TXT文件转化为XML格式。
(3)TXT转为XML的更多相关文章
- Java 将Word转为PDF、PNG、SVG、RTF、XPS、TXT、XML
同一文档在不同的编译或阅读环境中,需要使用特定的文档格式来打开,通常需要通过转换文档格式的方式来实现.下面将介绍在Java程序中如何来转换Word文档为其他几种常见文档格式,如PDF.图片png.sv ...
- BIP_开发案例07_将原有Report Builer报表全部转为XML Publisher形式(案例)
2014-05-31 Created By BaoXinjian
- 网站robots.txt & sitemap.xml
1. 如何查看网站的robots.txt 网址/robots.txt, 比如小米 https://www.mi.com/robots.txt sitemap.xml
- solr6.6 导入 文本(txt/json/xml/csv)文件
参照:solr6.6 导入 pdf文件 重点就是三个配置文件 1.建立的data-config.xml 内容如下: <dataConfig> <dataSource name=&qu ...
- Java 将Word转为XML,XML转为Word的方法
本文介绍将Word和XML文档进行双向互转的方法.转换时,Word支持.docx/.doc等格式. 代码环境如下: Word测试文档:.docx或.doc 编译环境:IntelliJ IDEA JDK ...
- C# 将HTML转为XML
本文以C#及VB.NET后端程序代码示例展示如何将HTML转为XML文件.转换时,调用Word API -Free Spire.Doc for .NET 提供的文档加载方法及文档保存的方法来实现.转换 ...
- Java 将HTML转为XML
本文介绍如何通过Java后端程序代码来展示如何将html转为XML.此功能通过采用Word API- Free Spire.Doc for Java 提供的Document.saveToFile()方 ...
- Java 将Excel转为XML
可扩展标记语言(XML)文件是一种标准的文本文件,它使用特定的标记来描述文档的结构以及其他特性.通常,我们可以通过格式转换的方式来得到XML格式的文件.本文,将通过Java代码介绍如何实现由Excel ...
- 使用php将数组转为XML
<?php class Array_to_Xml { private $version = '1.0'; private $encoding = 'UTF-8'; private $root = ...
随机推荐
- 项目文件包含 ToolsVersion="12.0" 设置,而此版本的 MSBuild 不支持该工具版本
解决方法: 右键点击你的项目,选择属性,再点击配置属性中的常规,常规中有个平台工作集,把V120改成V100,点击应用即可.
- 【python】 开始第一个项目
根据这篇文章开始上手 http://www.oschina.net/translate/the-flask-mega-tutorial-part-i-hello-world 再加点东西 如果你的环境是 ...
- ThinkPHP/Common/extend.php
<?php // +---------------------------------------------------------------------- // | ThinkPHP [ ...
- 设置NODE_ENV=production
NodeJS - Express 4.0下设置环境变量NODE_ENV=production,并不是修改文件的配置信息,而是通过命令行来实现. 首先在命令行下进入项目的目录,然后先后执行如下命令: s ...
- c语言函数指针的理解与使用
1.函数指针的定义 顾名思义,函数指针就是函数的指针.它是一个指针,指向一个函数.看例子: A) char * (*fun1)(char * p1,char * p2); B) char * *fun ...
- WPF解析TTF 字体
偶遇需要自己解析 TTF 字体并显示,此做... using System; using System.Collections.Generic; using System.Drawing.Text; ...
- Winform 文件控件 - 转
1. OpenFileDialog private void openFileDialogBTN_Click(object sender, System.EventArgs e) { OpenFile ...
- C# 越来越复杂了
自从三年前来到现在的公司以后,基本上不怎么使用.NET进行开发了.但最近因为公司有个CRM的项目,所以只有重新检起.NET进行开发. 因为近3年没有搞.NET的开发了,因此也不敢乱整个框架,在看了一周 ...
- 1458: 士兵占领 - BZOJ
Description 有一个M * N的棋盘,有的格子是障碍.现在你要选择一些格子来放置一些士兵,一个格子里最多可以放置一个士兵,障碍格里不能放置士兵.我们称这些士兵占领了整个棋盘当满足第i行至少放 ...
- BZOJ 3436: 小K的农场 差分约束
题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=3436 题解: 裸的差分约束: 1.a>=b+c -> b<=a-c ...