3

我有一个场景,其中员工记录写在平面文件中,例如:

flatFile.txt
============
1|name1|dept1|10000
2|name2|dept2|12000
3|name3|dept3|9500
....
....

现在我想每次都读取这个平面文件并将上面的员工记录转换成一些新的 xml 文件,所以最后我应该有以下数据的 xml 文件:

<EMPLOYEES>
    <EMPLOYEE>
        <ID>1</ID>
        <NAME>name1</NAME>
        <DEPARTMENT>dept1</DEPARTMENT>
        <SALARY>10000</SALARY>
         </EMPLOYEE>
    <EMPLOYEE>
        <ID>2</ID>
        <NAME>name2</NAME>
        <DEPARTMENT>dept2</DEPARTMENT>
        <SALARY>12000</SALARY>
         </EMPLOYEE>
         ...
         ...
</EMPLOYEES>

现在要实现这个概念,我需要处理数据的验证,例如:

  1. 身份证和工资应该是数字
  2. 名称长度应小于 20
  3. 平面文件的单行应包含以上 4 个字段

如果任何验证失败,则需要将它们与错误行号一起反映在 xml 文件中,例如:

<NAME type="Error" Line="2"></NAME> (name length is greater than 20 in 2nd record of a flat file)

或者

<EMPLOYEE type="Error" Line="1"></EMPLOYEE> (first record doesn't contains enough fields)

现在应用程序需要以这样一种方式设计,即组件可以插入替代品。例如,应该可以将用于基于分隔符解析输入文件的解析器替换为另一个将其解析为固定长度的解析器。

所以不知何故,我将不得不以分层的方式设计这个概念,比如

Parsing -> Validation -> Output Generation.

现在为了实现这个概念,我给出了一个想法,如下:

  1. 使用 BufferedReader 从文件中读取所有记录并使用 StringTokenizer 对其进行标记。
  2. 为每条记录初始化员工对象并将它们添加到某个集合(列表)中。
  3. 将错误(字段不匹配或任何其他验证失败)保留到 Map>。
  4. 使用一些 XML Builder API 将列表写入或编组到 xml 中(不清楚哪个是最好的)。

谁能给我更好的建议或任何提示来实现实施?

4

2 回答 2

3

自 Java SE 6 起,我将使用 JDK/JRE 中可用的库来执行以下操作。

  1. 创建一个 StAX (JSR-173)XMLStreamWriter以将 XML 内容输出到文件。
  2. 使用XMLStreamWriter来编写根元素。
  3. 阅读输入的下一行
  4. 将其转换为Employee对象
  5. 使用 JAXB (JSR-222) 将对象编组到XMLStreamWriter
  6. 如果有另一行重复步骤 3。
  7. 使用XMLStreamWriter结束文档。

更新

执行实际验证有不同的选项,下面我将演示如何在 JAXB 实现可以用来产生所需结果的对象模型中表示结果信息。

员工

package forum12446506;

import javax.xml.bind.annotation.*;

@XmlRootElement(name="EMPLOYEE")
public class Employee {

    @XmlAttribute(name="Line")
    Integer line;

    @XmlAttribute
    String type;

    @XmlElement(name="ID")
    Value id;

    @XmlElement(name="NAME")
    Value name;

    @XmlElement(name="DEPARTMENT")
    Value department;

    @XmlElement(name="SALARY")
    Value salary;

    public Employee() {
    }

    public Employee(int line, String type) {
        this.line = line;
        this.type = type;
    }

}

价值

package forum12446506;

import javax.xml.bind.annotation.*;

@XmlAccessorType(XmlAccessType.FIELD)
public class Value {

    @XmlAttribute(name="Line")
    Integer line;

    @XmlAttribute
    String type;

    @XmlValue
    String value;

    public Value() {
    }

    public Value(Integer line, String type, String value) {
        this.line = line;
        this.type = type;
        this.value = value;
    }

}

输出

<EMPLOYEE>
    <ID>1</ID>
    <NAME type="Error" Line="1"/>
</EMPLOYEE>

<EMPLOYEE type="Error" Line="2"/>
于 2012-09-16T14:24:55.677 回答
1

阅读下面提到的教程链接,了解如何将平面文件转换为 xml,请务必完整阅读,此外,为您提供本教程的原因是让您意识到没有神奇的 jumbo - mumbo to convert flat文件直接进入xmlbut yes there is a proper way to do it.....

http://cafeconleche.org/books/xmljava/chapters/ch04.html

于 2012-09-16T12:22:57.410 回答