(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 = ...
随机推荐
- Async详解之一:流程控制
为了适应异步编程,减少回调的嵌套,我尝试了很多库.最终觉得还是async最靠谱. 地址:https://github.com/caolan/async Async的内容分为三部分: 流程控制:简化十种 ...
- 深入理解用mysql_fetch_row()以数组的形式返回查询结果
同mysql_result()一样,mysql_fetch_row()也可以用来获取查询结果集,其区别在于函数的返回值不是一个字符串,而是一个数组.函数定义如下. 复制代码 代码如下: array m ...
- How to: Add Missing ContentPlaceHolder
In Microsoft SharePoint Server 2010, the BlueBand master page is not supported in the Search Center ...
- Android-Empty-Layout:展示不同类型的页面布局,用于视图是空的时候
Android-Empty-Layout:这个布局可以作用在Listview,Gridview,用于显示数据的是空的时候,可以提示友好的页面.这库可以显示页面出错,页面加载,页面是空. 加载的动画页面 ...
- git@oschina.net源代码管理使用日记
git的优势: 1 可以创建分支: 2 版本控制是基于每一次提交的,而不需要考虑每次提交了多少个文件. 下载: 下载网址为:http://git-scm.com/download,根据您的操作系统选择 ...
- shell dev null 是什么
1:在不想把标准输出和标准出错信息输出到控制台,也不想重定向到文件时经常使用 2:不能忽略其读入功能.从/dev/null读入时都是0 3:系统的垃圾桶,类似于Windows的回收站,不同的是这个设备 ...
- Eclipse插件安装总结
Eclipse的插件安装分为在线安装和离线安装两类: 1.在线安装(新版本的推荐方式) 最常用和最好用的方式,直接使用Eclipse的Ecliplse Marketplace,搜索你需要的插件,然后点 ...
- asynDBCenter(修改)
asynDBCenter加入数据库心跳,其实是没有找到更好的方法,看看和以前有什么不同 mongo数据库重练,暂时没有找到好办法,只能这样定时访问 bool asynDBCenter::init(bo ...
- C# Socket服务器端如何判断客户端断开
使用Socket类中的Poll方法,就可以. Socket client //假如已经创建好了,连接到服务器端得Socket的客户端对象. 我们只要client.Poll(10,SelectMode. ...
- ssh 内在溢出
相信有一定java开发经验的人或多或少都会遇到OutOfMemoryError的问题,这个问题曾困扰了我很长时间,随着解决各类问题经验的积累以及对问题根源的探索,终于有了一个比较深入的认识. 在解决j ...