`

通过反射获取xml内容,并封装到List<Object>对象

阅读更多
这里通过反射对一个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数据转换为Map 支持03和07(xls/xlsx)

    Map&lt;String, Object&gt; rowMap = new HashMap&lt;&gt;(); for (int i = 0; i &lt; row.getLastCellNum(); i++) { Cell cell = row.getCell(i); // 跳过空单元格 if (cell == null || cell.getCellType() == CellType.BLANK...

    java用poi解析excel2003和2007并封装成对象返回

    在实际项目中,可以将以上代码封装成一个通用的工具类,提供读取Excel并转换为List&lt;Object&gt;的方法。这样,无论Excel文件是2003还是2007格式,都可以轻松处理。同时,可以考虑添加错误处理、性能优化等细节,以提高...

    dom4j解析xml,利用反射机制

    在这个项目中,我们利用DOM4J来解析XML文件,并通过Java的反射机制将解析出的信息存储到特定的类中。 首先,我们需要了解XML的基本概念。XML(Extensible Markup Language)是一种标记语言,常用于数据交换和结构化...

    spring data redis 封装使用

    RedisTemplate&lt;String, Object&gt; template = new RedisTemplate&lt;&gt;(); template.setConnectionFactory(factory); // 使用protostuff序列化 ProtostuffSerializer serializer = new ProtostuffSerializer(); ...

    Spring/泛型Hibernate的实现

    public List&lt;T&gt; find(String hql, Object... values) { return (List&lt;T&gt;) this.hibernateTemplate.execute(new HibernateCallback() { @Override public Object doInHibernate(Session session) throws ...

    java中生成Excel表的封装类

    public void outExcel(String outputPath, String sheetName, List&lt;List&lt;Object&gt;&gt; data) throws IOException { // 创建Workbook对象 Workbook workbook = new XSSFWorkbook(); // 创建Sheet对象 Sheet sheet =...

    java Excel 导入导出

    List&lt;List&lt;String&gt;&gt; data = new ArrayList&lt;&gt;(); for (Row row : sheet) { List&lt;String&gt; rowData = new ArrayList&lt;&gt;(); for (Cell cell : row) { rowData.add(cell.getStringCellValue()); } data.add(rowData...

    Apache POI 导出Excel工具类的实现,超简单实用

    public static void exportToExcel(List&lt;List&lt;Object&gt;&gt; data, List&lt;String&gt; headers, OutputStream outputStream) { // 实现以上步骤的逻辑 } } ``` 8. **使用示例** 在你的业务代码中,只需要调用这个工具...

    poi-util.zip

    它可以将数据解析为 List&lt;List&lt;Object&gt;&gt; 或自定义对象列表,便于后续处理。你只需指定工作表索引、数据起始行和数据类型映射规则,即可完成数据的读取。 3. **高级功能:** POI 提供了丰富的 API,可以处理更复杂...

    Spring 和hibernate集成自学笔记

    List&lt;User&gt; find(String queryString, Object value); // 示例:List&lt;User&gt; users = this.getHibernateTemplate().find("from bean.User u where u.name=?", "test"); ``` - **模糊查询** ```java List&lt;User&gt; ...

    Spring笔记之整合JdbcTemplate.doc

    List&lt;Person&gt; persons = jdbcTemplate.query("SELECT * FROM t_person", new PersonRowMapper()); persons.forEach(System.out::println); ``` #### 三、声明式事务管理 在Spring中,可以通过注解或XML配置的方式...

    Flex中Tree组件的数据源举例(xml,array,object)

    &lt;xml&gt; &lt;root&gt; &lt;category name="Category 1"&gt; &lt;item&gt;Item 1.1&lt;/item&gt; &lt;item&gt;Item 1.2&lt;/item&gt; &lt;/category&gt; &lt;category name="Category 2"&gt; &lt;item&gt;Item 2.1&lt;/item&gt; &lt;/category&gt; &lt;/root&gt; &lt;/xml&gt; ``` 然后在Flex...

    JDBC数据库连接池DBCP jsp页面直接获取DAO层数据 demo

    List&lt;User&gt; users = new ArrayList&lt;&gt;(); try (Connection conn = dataSource.getConnection(); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users")) { while...

    springboot dbutils

    return jdbcTemplate.query(sql, new BeanPropertyRowMapper&lt;&gt;(User.class)); } // other CRUD method implementations } ``` 5. **Service层** Service层封装了业务逻辑,调用DAO层进行数据操作。例如...

    XML轻松学习手册--XML肯定是未来的发展趋势,不论是网页设计师还是网络程序员,都应该及时学习和了解

    你可以将上面的myfile.xml修改一下,比如将&lt; email&gt;改为&lt; Email&gt;,然后用IE5直接打开myfile.xml,会得到一个出错信息页面: &lt;?xml version="1.0" encoding="GB2312"?&gt; &lt;myfile&gt; &lt;title&gt;XML轻松学习手册&lt;/title&gt; ...

    java导出word步骤整理

    Map&lt;String, Object&gt; map = new HashMap&lt;&gt;(); map.put("trackingNumber", orderPerson.getTrackingNumber()); map.put("senderCompany", orderPerson.getSenderCompany()); map.put("senderName", orderPerson....

    Mybatis.docx

    5. **结果封装**:Mybatis 可以根据映射文件中的配置自动将查询结果封装到指定的实体类中,例如 `List&lt;User&gt;`。 6. **资源释放**:操作完成后,记得关闭 `SqlSession` 以释放资源。 **映射配置中的实体类指定** ...

    Java中如何解析XML文件

    List&lt;Student&gt; stuArrList = new ArrayList&lt;&gt;(); // 创建用来保存学生信息的集合。 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); try { DocumentBuilder builder = factory....

    Spring MVC不能直接接收list类型参数的问题

    首先定义一个 VO (Value Object) 类,其中包含 `List&lt;String&gt;` 类型的属性。 **VO 定义示例**: ```java public class ParamVo { private List&lt;String&gt; areaList; public List&lt;String&gt; getAreaList() { return ...

    hibernate将本地SQL查询结果封装成对象

    List&lt;Object[]&gt; objects = query.list(); ``` 以上代码会返回一个Object数组列表,每个数组元素对应一条记录,需要手动将它们转换为自定义的对象。 总结起来,Hibernate的本地SQL查询功能为我们提供了一种灵活的...

Global site tag (gtag.js) - Google Analytics