把数据转换成XML格式的好处

2016-02-19 21:15 14 1 收藏

下面图老师小编要跟大家分享把数据转换成XML格式的好处,简单的过程中其实暗藏玄机,还是要细心学习,喜欢还请记得收藏哦!

【 tulaoshi.com - Web开发 】

    我们常常会碰到需要处理以各种格式(从以逗号或者制表符做分隔符的文件到更负载的格式)保存或者传输的数据的情况,对每一种格式你都需要对应的解析器(parser)。这一缺点减缓了开发进度,而且可能会导致错误的发生。一个解决方案就是把常用格式的数据转化成XML文档,然后对它进行保存、处理或者转换成其它格式。
  一个实例
  

  现在已经有好多种实现在软件内部或者软件之间进行数据保存、导出、导入以及传输功能的数据格式。最常见的是定界格式(delimited format),如逗号或者制表符分隔数据格式以及定长数据格式。假设我们有一个地址簿程序,该程序提供把数据导出成逗号分隔以及固定长度这两种格式的功能。
  
  在逗号分隔格式中,用逗号来分隔同一个数据记录中的不同字段,如清单A所示。而在固定长度数据格式中,记录的每一个字段都应该有一个标准长度。清单B给出了一个固定长度格式的地址簿。
  

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)创建XML文档
  

  现在,让我们解析输入数据并把它转换成XML文档。XML文档(即org.w3c.dom.Document)是全部文档对象模型(DOM)的原始数据类型,并且它提供了对文档数据的访问。
  
  你可以用执行buildDocument(InputStream is)方法来创建与你的数据对应的文档,如代码清单C所示。该方法逐行读取输入数据流,并根据给定格进行来逐行分析。
  
  如果你想解析分界格式数据,你需要创建构造函数为PlainTextToXmlFormatter(String[ ] colName,String delim)的类的实例,其分界符可以是任何字符串。在固定长度格式的情况下,你应该使用第二种构造函数PlainTextToXmlFormatter(String[ ] colName,int[ ] colLen),它的一个参数为字段长度数组。在我们所给的地址簿例子中,各字段的长度分别为10、10、30以及10个字符。参数colName是保存了目标数据记录的名字的数组,在我们给出的这个例子中,名字分别为名(firstName)、姓(lastName)、email以及电话号码(phone)。
  
  把数据行转换为数据符号的实际解析过程也就是执行getStringArray(String read,String delim)或者parseFixedLengthMessage(String read,int[ ] colLen)方法的过程。其返回值是一个String型数组,这个数组是上述两个方法把给定输入进行分解而得来的。如果数据格式不对,就会抛出一个例外并且终止解析过错。调用setSkipError(true)方法就可以忽略例外并完成数据解析过程。调用这个方法可以防止抛出例外,但它仍允许程序向错误输出流打印错误信息。
  
  当行被解析成标记后,它们作为XML文档的元素而加入到XML文档之中。放入到元素之中的每一行记录都有一个默认的名字line,你也可以调用setDataLineName()来指定名字。每一个数据记录都是一个列元素,列元素的名字由相应的类构造函数提供,子元素加到行元素之中。
  
  在输入数据完全读取之后,你就得到了一个有效的XML文档,你可以进一步处理这个文档。现在,由于数据是按众所周知的树状结构来组织的,因此处理它非常简单。例如,你可以把这个文档送交给第三方,只要第三方知道该文档的文档类型定义(Document Type Definition ,DTD),那么他就可以很容易的处理文档了。你还可以调用writeDocument(Document doc,OutputStream osOut)方法来保存这个文档。代码清单D就给出一个把XML文档保存到一个文件中的例子。
  

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)用XSLT转换来查看数据
  

  你还可以把XML数据转换成其它格式,并用不同的视图来表示其内容。最简单的方法就是使用XSLT转换,它提供了一种强大的面向树的转换语言实现,可以把使用一种词汇表的XML实例转换成简单文本、HTML或者使用其它词汇表的XML。
  
  对给定的XML输入,你可以用XSLT语言来创建你所期望的输出。例如,通过执行transformData(InputStream xmlIn,InputStream xslIn,OutputStream transfOut),你就可以把XML数据转换成一个HTML文档。代码清单E提供了XSLT转换的一个例子,而清单F给出了地址簿条目的HTML视图。
  

简化对数据的管理
  

  在本文中,我们通过分析PlainTextToXmlFormatter类而学会了如何把常用格式数据转换成XML文档。我们还看到了如何借助于XSLT转换而用不同的视图来表示XML文档。当你需要处理各种格式的数据时,采纳上述技术或许就就是一个好的解决方案,从而节省了你的宝贵时间并减少了出错的可能性。

来源:http://www.tulaoshi.com/n/20160219/1625656.html

延伸阅读
怎样把jpg转换成word 怎样把jpg转换成word在找寻资料的时候,我们经常会发现一些Word文件中的文字资料是以图片的形式插在Word中的,如果我们需要这些资料,而又希望对这些图片内容进行编辑的话,那就只能想办法将图片文字提取出来了。可是,Word 中图片转换成文字的方法有哪些呢? 要想将Word中图片文字提取出来,必须靠专业的图片文...
怎么把excel转换成pdf 方法1: 很多用户都知道,excel2007及以后的版本,可以直接将excel文件另存为 PDF格式。步骤如下:打开需要转换的Excel文件,并调整好格式,然后点击左上角的office图标,打开图标后选择另存为,并点击PDF或 XPS,在弹出的对话框中,点击右下角的选项,在弹出的对话框中,点击选项按钮选择好我们需要的内容,...
标签: 电脑入门
如何把word文档转换成图片 将Word文件的全部内容或部分文字转化为图形形式具体操作方法如下: (1)打开需转化为图形格式的文件,单击插入→对象命令,在对象类型下拉列表中选择 MicrosoftWord文件项,单击确定按钮。 (2)Word系统会自动新建一个文件,在该文件中输入需要转换为图形的文字(可以通过复制→粘贴操作来实现),...
如何把pdf转换成word 在日常的办公生活中,Word文档和PDF文档是大家比较常见的两种文件格式,很多时候由于工作的需要,我们要将PDF文档转换成Word文档,在这种情况下,很大一部分用户都不知到该如何操作。虽然目前网络上有很多PDF转换软件,可是很多用户都对此一无所知,也不清楚这些PDF转换软件之间有什么区别。针对这种情况,小编就在这...
如何把PDF转换成Excel 网上可以找到许多支持转换PDF转Excel 的软件,哪款PDF转换成Excel转换器转换速度快,兼容性最佳,操作最简单呢?今天,笔者就来跟大家分享这样一款专业办公转换器:迅捷PDF转 Excel转换器,除了快速导出PDF文本中文字、图片、链接,还能去除文本中的水印、调整排版等功能。 1、安装PDF转Excel转换器 ...

经验教程

233

收藏

35
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部