java获取xml文件编码_读取用Java编写的UTF16编码的XML文件

我试图用Java读取UTF-16 xml文件 . 该文件是用C#编写的 .

这是java代码:

import java.io.File;

import javax.xml.parsers.DocumentBuilder;

import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;

import org.w3c.dom.Element;

import org.w3c.dom.Node;

import org.w3c.dom.NodeList;

public class XMLReadTest

{

public static void main(String[] s)

{

try

{

File fXmlFile = new File("C:\\my_file.xml");

DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();

DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();

Document doc = dBuilder.parse(fXmlFile);

doc.getDocumentElement().normalize();

NodeList nList = doc.getElementsByTagName("row");

for (int temp = 0; temp < nList.getLength(); temp++)

{

Node nNode = nList.item(temp);

if (nNode.getNodeType() == Node.ELEMENT_NODE)

{

Element eElement = (Element) nNode;

System.out.println("FILE_NAME: " + eElement.getElementsByTagName("FILE_NAME").item(0).getTextContent());

}

}

}

catch(Exception ex)

{

ex.printStackTrace();

}

}

}

这是xml文件:

Выписка_Винтовые насосы.pdf

GENERAL

在eclipse和Run / Debug设置窗口中运行此代码时,在名为“Common”的最后一个选项卡中,所选编码是Default - Inherited(Cp1253),我得到的输出是错误的:

文件名: ???????_???????? ?????? . PDF

当同一选项卡中的selecdted编码为UTF-8时,输出正常:

FILE_NAME:Выписка_Винтовыенасосы.pdf

我究竟做错了什么?

如何在eclipse项目设置中使用默认编码(cp 1253)获得正确的输出?

此代码在服务器中运行,我不想更改虚拟机的默认编码 .

我用Java 7和Java 8测试了这段代码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面给出一个Java读取XML文件生成实体的示例,并在其中实现一个抽象方法。 假设我们有一个Person实体类,它有name和age两个属性: ```java public class Person { private String name; private int age; // 构造方法 public Person(String name, int age) { this.name = name; this.age = age; } // getter和setter方法 public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } // 抽象方法 public abstract void speak(); } ``` 在这个示例中,我们定义了一个抽象方法speak(),它没有具体的实现。 接下来,我们创建一个XML文件,用来存储Person对象的数据: ```xml <?xml version="1.0" encoding="UTF-8"?> <persons> <person> <name>张三</name> <age>20</age> </person> <person> <name>李四</name> <age>25</age> </person> </persons> ``` 然后,我们编写一个XML解析器,读取XML文件并生成Person对象: ```java import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NodeList; public class XmlParser { public static void main(String[] args) throws Exception { // 创建DocumentBuilderFactory对象 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); // 创建DocumentBuilder对象 DocumentBuilder db = dbf.newDocumentBuilder(); // 解析XML文件,得到Document对象 Document doc = db.parse("persons.xml"); // 获取所有person节点 NodeList nodeList = doc.getElementsByTagName("person"); // 遍历所有person节点,创建Person对象 for (int i = 0; i < nodeList.getLength(); i++) { Element element = (Element) nodeList.item(i); String name = element.getElementsByTagName("name").item(0).getTextContent(); int age = Integer.parseInt(element.getElementsByTagName("age").item(0).getTextContent()); Person person = new Person(name, age); // 调用抽象方法 person.speak(); } } } ``` 在这个示例中,我们使用DOM解析解析XML文件,遍历所有person节点,创建Person对象,并调用抽象方法speak()。 我们可以在Person类的子类中实现speak()方法,并在XmlParser中创建子类对象,然后调用speak()方法。 ```java public class ChinesePerson extends Person { public ChinesePerson(String name, int age) { super(name, age); } @Override public void speak() { System.out.println("我是中国人"); } } public static void main(String[] args) throws Exception { // ... // 创建ChinesePerson对象,并调用speak()方法 Person person = new ChinesePerson(name, age); person.speak(); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值