这里通过反射对一个xml文件的内容进行遍历, 并将结果封装到List<Object>中。
这里的遍历方法要传入一个class对象。
这里的class的这个类里的属性必须和xml文件里的node的名称一致。(包括id,node里面必须有一个attribute id)
写的不是一般的乱。 以后再整理吧。
package com.lj.test;
import java.io.File;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import com.lj.model.Kanji;
import com.lj.readGoi.PathUtil;
import com.lj.readGoi.ReadXml;
public class Test04
{
public static void main(String[] args) throws Exception
{
SAXReader reader=new SAXReader();
Document doc=reader.read(new File(PathUtil.getPathByName("n1_eng.xml", Test04.class)));
Element root=doc.getRootElement();
// System.out.println(root.elements().size());
//
// System.out.println(root.elements().get(0));
//
// System.out.println(root.elementText("kanji"));
//
// System.out.println(copy(Kanji.class,root));
List<Object> list=copy(Kanji.class, root);
List<Kanji> re=new ArrayList<Kanji>();
for(Object o:list){
Kanji k=(Kanji) o;
re.add(k);
}
System.out.println(list);
System.out.println(re);
}
public static List<Object> copy(Class<?> clz,Element root ) throws Exception{
List<Object> result=new ArrayList<Object>();
ReadXml reader=new ReadXml();
Field[] fields=clz.getDeclaredFields();
List<Element> list=root.elements();
for(int i=0;i<list.size();i++){
Object objCopy=clz.getConstructor(new Class[]{}).newInstance(new Object[]{});
for(Field f:fields){
String name=f.getName();
System.out.println("name= "+name);
String firstLetter=name.substring(0, 1).toUpperCase();
String setMethodName="set"+firstLetter+name.substring(1, name.length());
Method setMethod=clz.getMethod(setMethodName, new Class[]{f.getType()});
Object obj=list.get(i);
System.out.println(list.get(i).elementText(name));
String xmlName=list.get(i).elementText(name);
if(name.equals("id")){
System.out.println("***********id************");
Integer id=Integer.parseInt(list.get(i).attribute(name).getText());
setMethod.invoke(objCopy, new Object[]{id});
}
System.out.println("xmlname= "+xmlName);
System.out.println("setMethod= "+setMethod.getName());
if(xmlName!=null){
setMethod.invoke(objCopy, new Object[]{xmlName});}
}
result.add(objCopy);
}
return result;
}
}
分享到:
相关推荐
在实际项目中,可以将以上代码封装成一个通用的工具类,提供读取Excel并转换为List<Object>的方法。这样,无论Excel文件是2003还是2007格式,都可以轻松处理。同时,可以考虑添加错误处理、性能优化等细节,以提高...
在这个项目中,我们利用DOM4J来解析XML文件,并通过Java的反射机制将解析出的信息存储到特定的类中。 首先,我们需要了解XML的基本概念。XML(Extensible Markup Language)是一种标记语言,常用于数据交换和结构化...
Map<String, Object> rowMap = new HashMap<>(); for (int i = 0; i < row.getLastCellNum(); i++) { Cell cell = row.getCell(i); // 跳过空单元格 if (cell == null || cell.getCellType() == CellType.BLANK...
RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); // 使用protostuff序列化 ProtostuffSerializer serializer = new ProtostuffSerializer(); ...
public List<T> find(String hql, Object... values) { return (List<T>) this.hibernateTemplate.execute(new HibernateCallback() { @Override public Object doInHibernate(Session session) throws ...
public void outExcel(String outputPath, String sheetName, List<List<Object>> data) throws IOException { // 创建Workbook对象 Workbook workbook = new XSSFWorkbook(); // 创建Sheet对象 Sheet sheet =...
List<List<String>> data = new ArrayList<>(); for (Row row : sheet) { List<String> rowData = new ArrayList<>(); for (Cell cell : row) { rowData.add(cell.getStringCellValue()); } data.add(rowData...
public static void exportToExcel(List<List<Object>> data, List<String> headers, OutputStream outputStream) { // 实现以上步骤的逻辑 } } ``` 8. **使用示例** 在你的业务代码中,只需要调用这个工具...
它可以将数据解析为 List<List<Object>> 或自定义对象列表,便于后续处理。你只需指定工作表索引、数据起始行和数据类型映射规则,即可完成数据的读取。 3. **高级功能:** POI 提供了丰富的 API,可以处理更复杂...
List<User> find(String queryString, Object value); // 示例:List<User> users = this.getHibernateTemplate().find("from bean.User u where u.name=?", "test"); ``` - **模糊查询** ```java List<User> ...
List<Person> persons = jdbcTemplate.query("SELECT * FROM t_person", new PersonRowMapper()); persons.forEach(System.out::println); ``` #### 三、声明式事务管理 在Spring中,可以通过注解或XML配置的方式...
<xml> <root> <category name="Category 1"> <item>Item 1.1</item> <item>Item 1.2</item> </category> <category name="Category 2"> <item>Item 2.1</item> </category> </root> </xml> ``` 然后在Flex...
List<User> users = new ArrayList<>(); try (Connection conn = dataSource.getConnection(); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users")) { while...
return jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); } // other CRUD method implementations } ``` 5. **Service层** Service层封装了业务逻辑,调用DAO层进行数据操作。例如...
你可以将上面的myfile.xml修改一下,比如将< email>改为< Email>,然后用IE5直接打开myfile.xml,会得到一个出错信息页面: <?xml version="1.0" encoding="GB2312"?> <myfile> <title>XML轻松学习手册</title> ...
首先定义一个 VO (Value Object) 类,其中包含 `List<String>` 类型的属性。 **VO 定义示例**: ```java public class ParamVo { private List<String> areaList; public List<String> getAreaList() { return ...
Map<String, Object> map = new HashMap<>(); map.put("trackingNumber", orderPerson.getTrackingNumber()); map.put("senderCompany", orderPerson.getSenderCompany()); map.put("senderName", orderPerson....
5. **结果封装**:Mybatis 可以根据映射文件中的配置自动将查询结果封装到指定的实体类中,例如 `List<User>`。 6. **资源释放**:操作完成后,记得关闭 `SqlSession` 以释放资源。 **映射配置中的实体类指定** ...
List<Student> stuArrList = new ArrayList<>(); // 创建用来保存学生信息的集合。 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); try { DocumentBuilder builder = factory....
List<Object[]> objects = query.list(); ``` 以上代码会返回一个Object数组列表,每个数组元素对应一条记录,需要手动将它们转换为自定义的对象。 总结起来,Hibernate的本地SQL查询功能为我们提供了一种灵活的...