jfow-代码分析

news2024/12/23 17:42:20

jfow-代码分析

  • 目录
    • 概述
      • 需求:
    • 设计思路
    • 实现思路分析
      • 1.代码:
      • 2.代码2:
      • 3.CashFrmTemplate
      • 4.chartType
      • 5.DataColumn
    • Data:
  • 参考资料和推荐阅读

Survive by day and develop by night.
talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for change,challenge Survive.
happy for hardess to solve denpendies.

目录

在这里插入图片描述

概述

需求:

设计思路

实现思路分析

1.代码:

package bp.da;

import bp.difference.ContextHolderUtils;
import bp.difference.SystemConfig;
import bp.en.Entities;
import bp.en.Row;
import bp.tools.StringUtils;

import java.util.Hashtable;

/**
 *  hashtable
 *  	--  entity
 *  		--  row
 */

/**
 实体缓存
*/
public class Cash2019
{

	 public static String redisKey = SystemConfig.getRedisCacheKey("Case2019");
	/**
	 清除所有的实体缓存.
	*/
/*	public static void ClearCash()
	{
//		_hts = null;
		ContextHolderUtils.getRedisUtils().del(false,redisKey);
	}*/

	//缓存ht
	// en-pk
//	private static Hashtable _hts;
//	public static Hashtable getHts()
//	{
//
//		_hts =ContextHolderUtils.getRedisUtils().hget(false,redisKey);
//		if (_hts == null)
//		{
//			_hts = new Hashtable<>();
//		}
//
//		return _hts;
//	}
	///对实体的操作.
	/** 
	 把实体放入缓存里面
	 
	 param enName
	 param pkVal
	 param row
	*/
	public static void PutRow(String enName, String pkVal, Row row)  {
//		synchronized (lockObj)
//		{
//			Object tempVar = getHts().get(enName);
//			Hashtable<String,Object> ht = tempVar instanceof Hashtable ? (Hashtable<String,Object>)tempVar : null;
//			if (ht == null)
//			{
//				ht = new Hashtable<>();
//				getHts().put(enName, ht);
//			}
//			ht.put(pkVal, row);
//			ContextHolderUtils.getRedisUtils().hset(false,redisKey,enName,ht, 300);
		if(StringUtils.isBlank(pkVal)) return;
			ContextHolderUtils.getRedisUtils().set(false, SystemConfig.getRedisCacheKey(enName + "_"+pkVal), row);
//		}
	}
	public static void UpdateRow(String enName, String pkVal, Row row)  {
//		synchronized (lockObj)
//		{
//			Object tempVar = getHts().get(enName);
//			Hashtable<String,Object> ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
//			if (ht == null)
//			{
//				ht = new Hashtable<>();
//				getHts().put(enName, ht);
//
//			}
//			ht.put(pkVal, row);
//			ContextHolderUtils.getRedisUtils().hset(false,redisKey,enName,ht, 300);
		if(StringUtils.isBlank(pkVal)) return;
			ContextHolderUtils.getRedisUtils().set(false, SystemConfig.getRedisCacheKey(enName + "_"+pkVal), row);
//		}
	}
	public static void DeleteRow(String enName, String pkVal)  {
//		synchronized (lockObj)
//		{
//			Object tempVar = getHts().get(enName);
//			Hashtable<String,Object> ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
//			if (ht == null)
//			{
//				ht = new Hashtable<>();
//				getHts().put(enName, ht);
//			}
//			ht.remove(pkVal.toString());
//			ContextHolderUtils.getRedisUtils().hset(false,redisKey,enName,ht,300);
		ContextHolderUtils.getRedisUtils().del(false, SystemConfig.getRedisCacheKey(enName + "_"+pkVal));
//		}
	}
//	private static final Object lockObj = new Object();
	/** 
	 获得实体类
	 
	 param enName 实体名字
	 param pkVal 键
	 @return row
	*/
	public static Row GetRow(String enName, String pkVal)  {
//		synchronized (lockObj)
//		{
		Object obj = ContextHolderUtils.getRedisUtils().get(false,SystemConfig.getRedisCacheKey(enName + "_"+pkVal));
		return obj==null ? null : (Row) obj;
		//			Object tempVar = getHts().get(enName);
//			Hashtable ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
//			if (ht == null)
//				return null;
//			if(DataType.IsNullOrEmpty(pkVal)==true)
//				return null;
//			if (ht.containsKey(pkVal) == true)
//			{
//				return ht.get(pkVal) instanceof Row ? (Row)ht.get(pkVal) : null;
//			}
//			return null;
//		}
	}


		/// 对实体的操作.


		///对实体的集合操作.
	/** 
	 把集合放入缓存.
	 
	 param ensName 集合实体类名
	 param ens 实体集合
	*/
//	public static void PutEns(String ensName, Entities ens)
//	{
//
//	}
	/** 
	 获取实体集合类
	 
	 param ensName 集合类名
	 param pkVal 主键
	 @return 实体集合
	*/
//	public static Entities GetEns(String ensName, Object pkVal)
//	{
//		return null;
//	}

}

2.代码2:

package bp.da;
import bp.difference.ContextHolderUtils;
import bp.difference.SystemConfig;
import bp.en.*;
import java.util.*;

public class CashEntity
{

		///Hashtable 属性
	private static Hashtable<String, Object> _Cash = new Hashtable<>();
	private static String dCashKey = SystemConfig.getRedisCacheKey("DCash");
	public static  Hashtable<String, Object> getDCash()throws Exception
	{
		_Cash = ContextHolderUtils.getRedisUtils().hget(false,dCashKey);
		return _Cash;
	}
	/** 
	 把实体放入缓存里面
	 param enName
	 param ens
	 param enPK
	 * @throws Exception 
	*/
	public static void PubEns(String enName, Entities ens, String enPK) throws Exception
	{
		Object tempVar = CashEntity.getDCash().get(enName);
		Hashtable ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
		if (ht == null)
		{
			ht = new Hashtable();
		}

		ht.clear();
		for (Entity en : ens)
		{
			ht.put(en.GetValStrByKey(enPK), en);
		}
		// 把实体集合放入.
		CashEntity.getDCash().put(enName + "Ens", ens);
		ContextHolderUtils.getRedisUtils().hset(false,dCashKey,enName + "Ens",ens);
	}
	public static Entities GetEns(String enName) throws Exception {
		Object tempVar = CashEntity.getDCash().get(enName + "Ens");
		Entities ens = tempVar instanceof Entities ? (Entities)tempVar : null;
		return ens;
	}
	/** 
	 更新对象
	 
	 param enName
	 param key
	 param en
	*/
	public static void Update(String enName, String key, Entity en) throws Exception {
		Object tempVar = CashEntity.getDCash().get(enName);
		Hashtable ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
		if (ht == null)
		{
			ht = new Hashtable();
			CashEntity.getDCash().put(enName, ht);
		}
		ht.put(key, en);
		//清除集合.
		CashEntity.getDCash().remove(enName + "Ens");
		//ContextHolderUtils.getRedisUtils().hset(false,enName,ht);
		ContextHolderUtils.getRedisUtils().hdel(false,dCashKey,enName + "Ens");
	}
	/** 
	 获取一个实体
	 
	 param enName 实体Name
	 param pkVal 主键值
	 @return 返回这个实体
	*/
	public static Entity Select(String enName, String pkVal) throws Exception {
		Object tempVar = CashEntity.getDCash().get(enName);
		Hashtable ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
		if (ht == null)
		{
			return null;
		}

		return ht.get(pkVal) instanceof Entity ? (Entity)ht.get(pkVal) : null;
	}
	/** 
	 删除
	 
	 param enName
	 param pkVal
	*/
	public static void Delete(String enName, String pkVal) throws Exception {
		Object tempVar = CashEntity.getDCash().get(enName);
		Hashtable ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
		if (ht == null)
		{
			return;
		}

		ht.remove(pkVal);
		//清除集合.
		CashEntity.getDCash().remove(enName + "Ens");
		ContextHolderUtils.getRedisUtils().hset(false,dCashKey,enName,ht);
		ContextHolderUtils.getRedisUtils().hdel(false,dCashKey,enName + "Ens");
	}
	/** 
	 插入
	 
	 param enName
	 param en
	 param pkVal
	*/
	public static void Insert(String enName, String pkVal, Entity en) throws Exception {
		Object tempVar = CashEntity.getDCash().get(enName);
		Hashtable ht = tempVar instanceof Hashtable ? (Hashtable)tempVar : null;
		if (ht == null)
		{
			return;
		}

		if (ht.containsKey(pkVal))
		{
			ht.put(pkVal, en);
		}
		else
		{
			ht.put(pkVal, en);
		}

		//清除集合.
		CashEntity.getDCash().remove(enName + "Ens");
		ContextHolderUtils.getRedisUtils().hset(false,dCashKey,enName,ht);
		ContextHolderUtils.getRedisUtils().hdel(false,dCashKey,enName + "Ens");
	}
}

3.CashFrmTemplate

package bp.da;

import bp.difference.ContextHolderUtils;
import bp.difference.SystemConfig;

public class CashFrmTemplate {

    ///对实体的操作.

    /**
     * 放入表单
     * <p>
     * param frmID 表单ID
     * param ds 表单模版
     *
     * @throws Exception
     */
    public static void Put(String frmID, DataSet ds) throws Exception {
        if (ds == null) return;
        String json = bp.tools.Json.ToJson(ds);
        ContextHolderUtils.getRedisUtils().set(false, SystemConfig.getRedisCacheKey(frmID), json);
    }

    /**
     * 移除
     * <p>
     * param frmID 表单ID
     */
    public static void Remove(String frmID) {
        ContextHolderUtils.getRedisUtils().del(false, SystemConfig.getRedisCacheKey(frmID));
    }

    /**
     * 获得表单DataSet模式的模版数据
     * <p>
     * param frmID 表单ID
     *
     * @return 表单模版
     */
    public static DataSet GetFrmDataSetModel(String frmID) throws Exception {
        Object result = ContextHolderUtils.getRedisUtils().get(false, SystemConfig.getRedisCacheKey(frmID));
        if (result != null) {
            DataSet ds = bp.tools.Json.ToDataSet(result.toString());
            return ds;
        }
        return null;
    }

    /**
     * 获得表单json模式的模版数据
     * <p>
     * param frmID 表单ID
     *
     * @return json
     */

    /// 对实体的操作.

}

4.chartType

package bp.da;



/** 
 图表类型
*/
public enum ChartType
{
	/** 
	 柱状图
	*/
	Histogram,
	/** 
	 丙状图
	*/
	Pie,
	/** 
	 折线图
	*/
	Line;

	public static final int SIZE = java.lang.Integer.SIZE;

	public int getValue()
	{
		return this.ordinal();
	}

	public static ChartType forValue(int value) 
	{
		return values()[value];
	}
}

5.DataColumn

package bp.da;

import java.util.HashMap;
import java.util.Map;

public class DataColumn
{
	
	/**
	 * DataColumn所屬的DataTable
	 */
	private DataTable table;
	/**
	 * DataColumn的欄位名稱
	 */
	public String ColumnName; // 欄名,當做DataRow的key
	public String oldColumnName; // 欄名,當做DataRow的key
	
	public void setColumnName(String val)
	{
	  if (oldColumnName==null)
		  oldColumnName= ColumnName;
	  
	   ColumnName=val;	  
	}
	
	public Object DataType;
	
	public Object getDataType()throws Exception
	{
		return DataType;
	}
	
	public void setDataType(Object dataType)
	{
		DataType = dataType;
	}
	
	/**
	 * DataColumn被建立時,一定要指定欄名
	 * 
	 * param columnName
	 *            欄名
	 */
	public DataColumn(String columnName)
	{
		this.ColumnName = columnName;
		this.oldColumnName = columnName;
	}
	
	public DataColumn()throws Exception
	{
		
	}
	
	public DataColumn(String columnName, Object DataType)
	{
		this.ColumnName = columnName;
		this.oldColumnName = columnName;
		this.DataType = DataType;
	}
	
	//区分大小写
	public DataColumn(String columnName, Object DataType, boolean cases)
	{
		this.ColumnName = columnName;
		this.oldColumnName = columnName;
		this.DataType = DataType;
	}
	
	public DataColumn(String columnName, Object DataType, String str)
	{
		this.ColumnName = columnName;
		this.oldColumnName = columnName;
		this.DataType = DataType;
	}
	
	/**
	 * 給DataColumnCollection加入DataColumn時設定所屬的DataTable的方法,同一個package才用到
	 * 
	 * param table
	 */
	void setTable(DataTable table)
	{
		this.table = table;
	}
	
	/**
	 * 取得DataColumn所屬的DataTable,唯讀
	 * 
	 * @return DataTable
	 */
	public DataTable getTable()throws Exception
	{
		return this.table;
	}
	
	/**
	 * DataColumn物件的toString(),會回傳自己的欄名
	 * 
	 * @return
	 */
	@Override
	public String toString()  {
		return this.ColumnName;
	}

	private int ordinal;

	public void setOrdinal(int ordinal) {
		this.ordinal = ordinal;
	}

	public int getOrdinal() {
		return ordinal;
	}

	public final Properties ExtendedProperties = new Properties();

	public static class Properties {

		private Map<Object, Object> properties = new HashMap<Object, Object>();

		public void Add(Object key, Object value) {
			this.properties.put(key, value);
		}

		public boolean ContainsKey(Object key) {
			return this.properties.containsKey(key);
		}

		public Object get(Object key) {
			return this.properties.get(key);
		}

	}

}

package bp.da;

import java.util.LinkedHashMap;
import bp.tools.StringUtils;

public class DataRow extends LinkedHashMap<String, Object>
{
	
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	
	/**
	 * 此資料列所屬的DataTable,唯讀
	 */
	public transient DataTable table;
	
	/**
	 * 在getValue()和setValue()時候,程式碼須透過此成員的欄位名稱來找出Map字典裡的物件
	 */
	public transient DataColumnCollection columns;

	public transient Object ItemArray;
	
	
	public Object getItemArray() {
		return ItemArray;
	}

	public void setItemArray(Object itemArray) {
		ItemArray = itemArray;
	}

	/**
	 * DataRow被建立時,必須指定所屬的DataTable
	 * 
	 * param table
	 */
	public DataRow(DataTable table)
	{
		this.table = table;
		this.columns = table.Columns;
	}
	
	/**
	 * 取得DataRow所屬的DataTable
	 * 
	 * @return DataTable
	 */
	public DataTable getTable()throws Exception
	{
		return this.table;
	}
	
	/**
	 * 設定該列該行的值
	 * 
	 * param columnIndex
	 *            行索引(從0算起)
	 * param value
	 *            要設定的值
	 */
	public void setValue(int columnIndex, Object value)
	{setValue(this.columns.get(columnIndex), value);
	}
	
	public void setDataType(int columnIndex, Object dataType)
	{
		this.columns.get(columnIndex).setDataType(dataType);
	}
	
	/**
	 * 設定該列該行的值
	 * 
	 * param columnName
	 *            行名稱
	 * param value
	 *            要設定的值
	 */
	public void setValue(String columnName, Object value)
	{this.put(columnName, value);
		// this.put(columnName, value);
	}
	
	public void setValue(String columnName, Boolean value)
	{if (value==true)
		this.put(columnName, 1);
		else
			this.put(columnName, 0);	
			
		// this.put(columnName, value);
	}
	
	public void setValueStr(String columnName, String value)
	{this.put(columnName, "\""+value+"\"");
		// this.put(columnName, value);
	}
	/**
	 * 設定該列該行的值 区分大小写
	 * 
	 * param columnName
	 *            行名稱
	 * param value
	 *            要設定的值
	 */
	public void setValue2017(String columnName, Object value)
	{this.put(columnName, value);
	}
	
	/**
	 * 設定該列該行的值
	 * 
	 * param column
	 *            DataColumn物件
	 * param value
	 *            要設定的值
	 */
	public void setValue(DataColumn column, Object value)
	{if (column != null)
		{
			String lowerColumnName = column.ColumnName;
			if (this.containsKey(lowerColumnName))
				this.remove(lowerColumnName);
			this.put(lowerColumnName, value);
		}
	}
	
	/**
	 * 区分大小写
	 * 
	 * param column
	 * param value
	 */
	public void setValue_UL(DataColumn column, Object value)throws Exception
	{if (column != null)
		{
			String lowerColumnName = column.ColumnName;
			// String lowerColumnName = column.ColumnName;
			if (this.containsKey(lowerColumnName))
				this.remove(lowerColumnName);
			this.put(lowerColumnName, value);
		}
	}
	
	/**
	 * 取得該列該行的值
	 * 
	 * param columnIndex
	 *            行索引(從0算起)
	 * @return Object
	 */
	public Object getValue(int columnIndex)
	{
		Object obj = this.get(this.columns.get(columnIndex).ColumnName);
		if (obj == null)
		{
			obj = "";
		}
		return obj;
		// return
		// this.get(this.columns.get(columnIndex).ColumnName.toLowerCase());
	}
	
	/**
	 * 取得該列該行的值
	 * 
	 * param columnName
	 *            行名稱
	 * @return Object
	 */
	public Object getValue(String columnName)
	{
		 
		Object obj = this.get(columnName);
		if (obj == null)
		{
			if(!DataType.IsNullOrEmpty(this.get(columnName.toLowerCase())))
				return this.get(columnName.toLowerCase());
			if(!DataType.IsNullOrEmpty(this.get(columnName.toUpperCase())))
				return this.get(columnName.toUpperCase());
			return "";
		}
		return obj;
	}
	
	/**
	 * 取得該列該行的值
	 * 
	 * param column
	 *            DataColumn物件
	 * @return Object
	 */
	public Object getValue(DataColumn column)
	{
		Object obj = this.get(column.ColumnName);
		if (obj == null)
		{
			obj = "";
		}
		return obj;
	}

	public void set(String string, Object object) {
		 
		if (object==null)
			object="";
		
		this.set(string, object.toString());
	}
}

package bp.da;

import java.util.ArrayList;
import java.util.Map;


import bp.difference.SystemConfig;

public class DataRowCollection extends ArrayList<DataRow>
{
	
	/**  
	 * 
	 */
	private static final long serialVersionUID = 1L;
	/**
	 * DataRowCollection所屬的DataTable,唯讀
	 */
	private transient DataTable Table;
	
	/**
	 * DataRowCollection被建立時,一定要指定所屬的DataTable
	 * 
	 * param table
	 */
	public DataRowCollection(DataTable table)
	{
		this.Table = table;
		
	}
	
	/**
	 * 取得所屬的DataTable
	 * 
	 * @return DataTable
	 */
	public DataTable getTable()throws Exception
	{
		return this.Table;
	}
	
	public DataRow AddRow(DataRow vals)
	{
		return AddRow(vals,-1);
	}
	 
	
	public DataRow AddRow(DataRow vals, int idx){
		
		if (vals==null)
			return null;
		 
		DataRow row = new DataRow(Table);
		
		Map ap=   ((Map<String, Object>) vals);
		
		for(DataColumn dc : Table.Columns)
		{

            String key= dc.ColumnName;
            String valStr=String.valueOf( ap.get(key)); 
            if((DataType.IsNullOrEmpty(valStr) ||"null".equals(valStr))
            		&& SystemConfig.AppCenterDBFieldCaseModel() == FieldCaseModel.Lowercase){
            	valStr=String.valueOf( ap.get(key.toLowerCase())); 
            }
			
			if (valStr==null)
				valStr="";
			row.setValue(key, valStr);
		}
       
		if (idx==-1)
	    	this.add(row);
		else
			this.add(row);
			
		return row;
	}
	
	public DataRow AddDatas(Object... vals){
		
		if (vals==null)
			return null;
		 
		
		DataRow row = new DataRow(Table);	
		int i=0;
			for (Object val : vals) {
				 
				
				String key = Table.Columns.get(i++).ColumnName;
				
				Object value;
				if (val instanceof Map) {
					value = ((Map<String, Object>) val).get(key);
				} else {
					value = val;
				}
				
				if (value==null)
					value="";
				
				row.put(key, value); 
			}
			this.add(row);
		
		return row;
	}
}

Data:

package bp.da;

import java.io.*;

import java.util.ArrayList;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.List;

import bp.difference.SystemConfig;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

import org.springframework.core.io.ClassPathResource;

public class DataSet {

	private String name;

	public List<DataTable> Tables;

	public Hashtable<String, DataTable> hashTables;


	public DataSet() {
		if (Tables == null) {
			Tables = new ArrayList<DataTable>();
			hashTables = new Hashtable<String, DataTable>();
		}
	}

	public boolean removeTableByName(String tableName)
	{

		for (DataTable dtb : this.Tables)
		{
			if( tableName.equals(dtb.getTableName()))
			{
				this.Tables.remove(dtb);
				return true;

			}
		}

		return false;

	}

	public DataTable GetTableByName(String tableName)
	{

		for (DataTable dtb : this.Tables)
		{
			if( tableName.equals(dtb.getTableName()))
			{
				return dtb;

			}
		}

		return null;

	}

	/**
	 * 判断DataSet中是否包含指定的名称的DataTable数据
	 * @param tableName
	 * @return
	 */
	public boolean contains(String tableName){
		boolean isHave=false;
		for (DataTable dtb : this.Tables)
		{
			if( tableName.equals(dtb.getTableName()))
			{
				isHave = true;
				break;
			}
		}
		return isHave;
	}

	public DataSet(String name)  {
		if (Tables == null) {
			Tables = new ArrayList<DataTable>();
			hashTables = new Hashtable<String, DataTable>();
		}
	}

	/**
	 * DataSet 以xml形式写入文件
	 *
	 * param file
	 * @throws Exception
	 */
	public void WriteXml(String file)  {
		WriteXml(file, XmlWriteMode.IgnoreSchema, new DataSet("NewDataSet"));
	}

	/**
	 * DataSet 以xml形式写入文件
	 *
	 * param path
	 * param mode
	 *            暂不支持DiffGram格式
	 * @throws Exception
	 */
	public void WriteXml(String path, XmlWriteMode mode, DataSet ds) {
		StringBuilder str = new StringBuilder("<?xml version=\"1.0\" standalone=\"yes\"?>");
		str.append("<NewDataSet>");
		// 输出表架构
		for (int i = 0; i < ds.Tables.size(); i++) {
			DataTable dt = ds.Tables.get(i);
			for (int k = 0; k < dt.Rows.size(); k++) {
				str.append("<");
				str.append(dt.getTableName());
				str.append(">");
				for (int j = 0; j < dt.Columns.size(); j++) {
					DataColumn dc = dt.Columns.get(j);

					str.append("<");
					str.append(dc.ColumnName);
					str.append(">");
					try {
						Object value = dt.Rows.get(k).getValue(dc);
						if (value.toString().contains(">") || value.toString().contains("<") || value.toString().contains("&")
								|| value.toString().contains("'") || value.toString().contains("\"")) {
							value = value.toString().replace(">", "&gt;");
							value = value.toString().replace("<", "&lt;");
							value = value.toString().replace("&", "&amp;");
							value = value.toString().replace("'", "&apos;");
							value = value.toString().replace("\"", "&quot;");
						}
						str.append(value);
					} catch (Exception e) {

					}
					str.append("</");
					str.append(dc.ColumnName);
					str.append(">");

				}
				str.append("</");
				str.append(dt.getTableName());
				str.append(">");
			}
		}
		// }
		str.append("</NewDataSet>");
		String temp = str.toString();
		int pathType=0;
		if(path.startsWith("resources")==true)
			pathType = 1;
		if(SystemConfig.getIsJarRun() && pathType==1){

		}
		// 写入文件
		File file = new File(path);
		try {
			if (!file.exists()) {
				file.createNewFile();
			}
			FileOutputStream fos = new FileOutputStream(file);
			OutputStreamWriter osw = new OutputStreamWriter(fos, "utf-8");
			BufferedWriter br = new BufferedWriter(osw);
			br.write(temp.toString());
			fos.flush();
			br.close();
			fos.close();
			osw.close();

		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	public String formatXml(String str) throws Exception {
		Document document = null;
		document = DocumentHelper.parseText(str);
		// 格式化输出格式
		OutputFormat format = OutputFormat.createPrettyPrint();
		format.setEncoding("gbk");
		StringWriter writer = new StringWriter();
		// 格式化输出流
		XMLWriter xmlWriter = new XMLWriter(writer, format);
		// 将document写入到输出流
		xmlWriter.write(document);
		xmlWriter.close();

		return writer.toString();
	}

	public void readXmls(String xmlPath) throws Exception {
		if (DataType.IsNullOrEmpty(xmlPath)) {
			return;
		}

		SAXReader reader = new SAXReader();

		File file = new File(xmlPath);
		// DataSet ds=new DataSet();
		if (file.exists()) {
			Document document = reader.read(file);// 读取XML文件
			Element root = document.getRootElement();// 得到根节点
			for (Iterator i = root.elementIterator(); i.hasNext();) {
				Element e = (Element) i.next();
				boolean type = false;
				for (int k = 0; k < this.Tables.size(); k++) {
					if (this.Tables.get(k).TableName.equals(e.getName())) {
						DataTable dt = this.Tables.get(k);
						DataRow dr = dt.NewRow();
						DataColumn dc = null;
						for (Iterator j = e.elementIterator(); j.hasNext();) {
							Element cn = (Element) j.next();
							dc = new DataColumn(cn.getName());
							dr.setValue(dc, cn.getText());
						}
						dt.Columns.Add(dc);
						dt.Rows.add(dr);
						type = true;
						break;
					}
				}
				if (type) {
					continue;
				}
				DataTable dt = new DataTable(e.getName());
				DataRow dr = dt.NewRow();
				DataColumn dc = null;
				for (Iterator j = e.elementIterator(); j.hasNext();) {
					Element cn = (Element) j.next();
					dc = new DataColumn(cn.getName());
					dt.Columns.Add(dc);
					dr.setValue(dc, cn.getText());
				}
				dt.Rows.add(dr);
				this.Tables.add(dt);
				this.hashTables.put(e.getName(), dt);
			}
		}
	}

	public void readXmlm(String xml) {
		if (DataType.IsNullOrEmpty(xml))
			return;
		try {
			xml = "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\r\n <NewDataSets>" + xml + "</NewDataSets>";
			// 创建xml解析对象
			SAXReader reader = new SAXReader();
			// 定义一个文档
			Document document = null;
			// 将字符串转换为
			document = reader.read(new ByteArrayInputStream(xml.getBytes("UTF-8")));
			@SuppressWarnings("unchecked")
			List<Element> elements = document.selectNodes("//NewDataSets/NewDataSet");

			int i = 0;
			DataTable oratb = new DataTable();
			for (Element element : elements) {
				DataRow dr = oratb.NewRow();
				@SuppressWarnings("unchecked")
				Iterator<Element> iter = element.elementIterator();
				int j = 0;
				while (iter.hasNext()) {
					Element itemEle = (Element) iter.next();
					if (i == 0) {
						oratb.Columns.Add(itemEle.getName());
					}
					dr.setValue(j, itemEle.getTextTrim());
					j++;
				}
				oratb.Rows.add(dr);
				i++;
			}
			this.Tables.add(oratb);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	public String getName() {
		return name;
	}

	public void setName(String name) throws Exception {
		this.setName( name);
	}

	public List<DataTable> getTables() {
		return Tables;
	}

	public void setTables(List<DataTable> tables) {
		Tables = tables;
	}

	public Hashtable<String, DataTable> getHashTabless() {
		return hashTables;
	}

	public void setHashTables(Hashtable<String, DataTable> hashTables) {
		this.hashTables = hashTables;
	}

	/**
	 * 获取文件的XML文件内容。
	 * param path xml文件路径
	 * @return xml文件内容
	 */
	public String xmlToString(String path) throws Exception {
		String line = null;
		StringBuffer strBuffer = new StringBuffer();
		int pathType =0;
		if((path.indexOf("DataUser/")!=-1 &&path.indexOf("DataUser/Siganture/")==-1 && path.indexOf("DataUser/UploadFile/")==-1 &&
		 path.indexOf("DataUser/FlowDesc/")==-1 && path.indexOf("DataUser/Temp/")==-1 )|| path.indexOf("WF/")!=-1)
			pathType =1;
		try {
			String encoding = "UTF-8"; // 字符编码
			if(SystemConfig.getIsJarRun() && pathType==1){
				ClassPathResource classPathResource = new ClassPathResource(path);
				InputStream inputStream = classPathResource.getInputStream();
				StringBuilder stringBuilder = new StringBuilder();
				BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream, encoding));
				StringBuffer buffer = new StringBuffer();
				while ((line = bufferedReader.readLine()) != null){
					buffer.append(line + "\n");
				}
				bufferedReader.close();
				return buffer.toString();
			}else{
				File file = new File(path);
				if (file.isFile() && file.exists()) {

					InputStreamReader read = new InputStreamReader(new FileInputStream(file), encoding);
					BufferedReader bufferedReader = new BufferedReader(read);
					while ((line = bufferedReader.readLine()) != null) {
						strBuffer.append(line + "\n");
					}
					read.close();
				} else {
					throw new Exception("找不到指定的文件"+path+",请联系管理员查看环境配置是否正确,jflow.properties中的配置是否正确");
				}
			}

		} catch (Exception e) {
			throw new Exception("读取文件内容操作出错!" + e.getMessage());
		}
		return strBuffer.toString();
	}

	/**
	 * 读取XML文件
	 * param xmlpath xml文件路径
	 * @author ThinkGem
	 */
	@SuppressWarnings("rawtypes")
	public void readXml(String xmlpath) {
		if (DataType.IsNullOrEmpty(xmlpath)){
			return;
		}
		try {
			String xml = xmlToString(xmlpath);
			Document document = new SAXReader().read(new ByteArrayInputStream(xml.getBytes("UTF-8")));
			Element element = document.getRootElement();

			// 遍历 DataTable
			for (Iterator iterator = element.elementIterator(); iterator.hasNext();) {
				Element el = (Element) iterator.next();
//				System.out.println(" ===================== " + el.getName());

				// 如果没有获取到DataTable则新建一个
				DataTable dt = hashTables.get(el.getName());
				if (dt == null){
					dt = new DataTable(el.getName());
					hashTables.put(el.getName(), dt);
					Tables.add(dt);
				}

				// 新增一行数据
				DataRow dr = dt.NewRow();
				dt.Rows.add(dr);

				// 遍历该DataTable的属性
				for (Iterator it = el.attributeIterator(); it.hasNext();) {
					Attribute at = (Attribute)it.next();
//					System.out.println(" ======= " + at.getName());
					//sunxd 修改
					//由于"at.getName().toLowerCase()"语句导至  isContains 方法判断永远不成立,会给TABLE插入很多重复列
					//将at.getName().toLowerCase() 修改为  at.getName()
					if (!iscontains(dt.Columns.subList(0, dt.Columns.size()), at.getName())) {
						dt.Columns.Add(at.getName());
					}
					dr.setValue(at.getName(), at.getValue());
				}

				// 遍历该DataTable的子元素
				for (Iterator it = el.elementIterator(); it.hasNext();) {
					Element at = (Element) it.next();

					if (!iscontains(dt.Columns.subList(0, dt.Columns.size()), at.getName())) {
						dt.Columns.Add(at.getName());
					}
					String value = at.getText();
					try {
						//导出模板进行了转义,现在进行反转 dgq 2018-7-5
						if (value.toString().contains("&gt;") || value.toString().contains("&lt;")
								|| value.toString().contains("&amp;") || value.toString().contains("&apos;")
								|| value.toString().contains("&quot;")) {
							value = value.toString().replace("&amp;", "&");
							value = value.toString().replace("&gt;",">");
							value = value.toString().replace("&lt;","<");
							value = value.toString().replace("&apos;","'");
							value = value.toString().replace("&quot;","\"");
						}
					} catch (Exception e) {

					}
					dr.setValue(at.getName(), value);
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	public boolean iscontains(List<DataColumn> dcList, String column) {
		for (DataColumn dc : dcList) {
			if (dc.ColumnName.equals(column)) {
				return true;
			}
		}
		return false;
	}

	public static String ConvertDataSetToXml(DataSet dataSet) {
		if (dataSet != null) {
			String str = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>";
			str += "<xs:schema id=\"NewDataSet\" xmlns=\"\" xmlns:xs=\"http://www.w3.org/2001/XMLSchema\" xmlns:msdata=\"urn:schemas-microsoft-com:xml-msdata\">";

			str += "<xs:element name=\"NewDataSet\" msdata:IsDataSet=\"true\" msdata:UseCurrentLocale=\"true\">";
			str += "<xs:complexType><xs:choice minOccurs=\"0\" maxOccurs=\"unbounded\">";
			// 循环每一个表的列

			for (int n = 0; n < dataSet.getTables().size(); n++) {
				str += "<xs:element name=\"" + dataSet.getTables().get(n).TableName + "\">";
				str += "<xs:complexType><xs:sequence>";
				DataTable table = dataSet.getTables().get(n);
				for (DataColumn col : table.Columns) {
					str += "<xs:element name=\"" + col.ColumnName;
					str += "\" type=\"";
					try {
						col.DataType.toString();
						str += IsType(col.DataType.toString());
					} catch (Exception e) {
						str += "xs:string";
					}
					str += "\" minOccurs=\"0\" />";
				}
				str += "</xs:sequence></xs:complexType></xs:element>";
			}
			str += "</xs:choice></xs:complexType></xs:element><_NewDataSet>";
			for (int i = 0; i < dataSet.getTables().size(); i++) {
				DataTable dt = dataSet.getTables().get(i);
				DataTable table = dataSet.getTables().get(i);
				for (int j = 0; j < table.Rows.size(); j++) {
					str += "<_" + i + ">";
					DataRow row = table.Rows.get(j);
					for (int a = 0; a < row.columns.size(); a++) {
						DataColumn col = table.Columns.get(a);
						str += "<_" + a + ">";
						if (row.getValue(col) == null) {
							str += "";
						} else {
							if (col.ColumnName.equals("icon")) {
								if (row.getValue(col).equals("")) {
									str += "审核";
								} else if (row.getValue(col).equals("Default")) {
									str += "审核";
								} else {
									str += row.getValue(col);
								}
							} else {
								str += row.getValue(col);
							}
						}
						str += "</_" + a + ">";

					}
					str += "</_" + i + ">";
				}
			}
			str += "</_NewDataSet>";
			str += "</xs:schema>";
			return str;
		}
		return null;
	}

	public static String IsType(String name) throws Exception {
		if (name.equals("class java.lang.Integer")) {
			name = "xs:int";
		}
		if (name.equals("class java.lang.Long")) {
			name = "xs:long";
		}
		if (name.equals("class java.lang.Float")) {
			name = "xs:float";
		}
		if (name.equals("class java.lang.Double")) {
			name = "xs:double";
		}
		if (name.equals("class java.lang.String")) {
			name = "xs:string";
		}
		if (name.equals("class java.math.BigDecimal")) {
			name = "xs:int";
		}
		return name;
	}

}
package bp.da;

import bp.difference.SystemConfig;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.springframework.core.io.ClassPathResource;

import java.io.*;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;


public class DataTable implements Cloneable
{

	/**
	 * 保存DataRow的集合,在DataTable初始化時,便會建立
	 */
	public DataRowCollection Rows;
	/**
	 * 保存DataColumn的集合,在DataTable初始化時,便會建立
	 */
	public DataColumnCollection Columns;
	/**
	 * DataTable的名稱,沒什麼用到
	 */
	public String TableName;
	private DataRow[] dataRows;


	/**
	 * @return 复制DataTable的结构
	 */
	public DataTable clone(){
		try
		{
			DataTable v = new DataTable();
			for(DataColumn Column: this.Columns){
				v.Columns.Add(Column.ColumnName,Column.DataType);
			}
			return v;
		} catch (Exception e)
		{
			throw new InternalError();
		}

	}

	/**
	 * @return 复制DataTable的结构与数据。
	 * @throws CloneNotSupportedException
	 */
	public DataTable copy()
	{
		try
		{
			DataTable v = (DataTable) super.clone();
			v.Rows = (DataRowCollection) this.Rows.clone();
			v.Columns = (DataColumnCollection) this.Columns.clone();
			return v;
		} catch (CloneNotSupportedException e)
		{
			throw new InternalError();
		}
	}

	/**
	 * 初始化DataTable,並建立DataColumnCollection,DataRowCollection
	 */
	public DataTable()  {
		this.Columns = new DataColumnCollection(this);
		this.Rows = new DataRowCollection(this);
	}

	/**
	 * 除了初始化DataTable, 可以指定DataTable的名字(沒什麼意義)
	 *
	 * param tableName DataTable的名字
	 */
	public DataTable(String tableName)  {
		this();
		this.TableName = tableName;
	}

	/**
	 * 由此DataTable物件來建立一個DataRow物件
	 *
	 * @return DataRow
	 */
	public DataRow NewRow()
	{

		DataRow row = new DataRow(this);// DataRow為呼叫此方法DataTable的成員

		return row;
	}

	/**
	 * 把DataTable當做二維陣列,給列索引和行索引,設定值的方法 <br/>
	 * (發佈者自行寫的方法)
	 *
	 * param rowIndex
	 *            列索引(從0算起)
	 * param columnIndex
	 *            行索引(從0算起)
	 * param value
	 *            要給的值
	 */
	public void setValue(int rowIndex, int columnIndex, Object value)throws Exception
	{this.Rows.get(rowIndex).setValue(columnIndex, value);
	}

	/**
	 * 把DataTable當做二維陣列,給列索引和行名稱,設定值的方法 <br/>
	 * (發佈者自行寫的方法)
	 *
	 * param rowIndex 列索引(從0算起)
	 * param columnName 行名稱
	 * param value 要給的值
	 */
	public void setValue(int rowIndex, String columnName, Object value)throws Exception
	{this.Rows.get(rowIndex).setValue(columnName.toLowerCase(), value);
	}

	/**
	 * 把DataTable當做二維陣列,給列索引和行索引,取得值的方法 <br/>
	 * (發佈者自行寫的方法)
	 *
	 * param rowIndex
	 *            列索引(從0算起)
	 * param columnIndex
	 *            行索引(從0算起)
	 * @return 回傳該位置的值
	 */
	public Object getValue(int rowIndex, int columnIndex)
	{
		return this.Rows.get(rowIndex).getValue(columnIndex);
	}

	public void Clear()
	{
		Rows.clear();
		Columns.clear();
	}

	public void ClearRow()throws Exception
	{
		Rows.clear();
	}

	public List<DataRow> Select(Map<String, Object> filterMap) throws Exception {

		List<DataRow> dataRowList = new ArrayList<DataRow>();
		outer: for (int i = 0; i < Rows.size(); i++)
		{
			DataRow row = Rows.get(i);
			for (Object key : filterMap.keySet().toArray())
			{
				Object lefteql = filterMap.get(key);
				Object righteql = row.getValue(key.toString());
				if (lefteql == null || "".equals(lefteql))
				{
					if (righteql == null || "".equals(righteql))
					{
						continue;
					} else
					{
						continue outer;
					}
				} else if (!filterMap.get(key).toString().toUpperCase().equals(
						row.getValue(key.toString()).toString().toUpperCase()))
				{
					continue outer;
				}
			}
			dataRowList.add(row);
		}
		return dataRowList;
	}

	/**
	 * 返回符合过滤条件的数据行集合,并返回
	 * param filterString 过滤字符串,例如  a>1 and a>=2 or a<3 and a<=4 or a!=5 and a=6 or a!='b' and a='c'
	 * @return 过滤后的 List<DataRow>
	 */
	public List<DataRow> select(String filterString) {
		List<DataRow> rows = new ArrayList<DataRow>();
		if (DataType.IsNullOrEmpty(filterString) == true)
			return this.Rows;

		boolean bl;
		for (Object row : this.Rows) {
			DataRow currentRow = (DataRow) row;
			try {
				bl = dataRowCompute(filterString, currentRow);
			} catch (Exception e) {
				System.err.println("语法错误");
				e.printStackTrace();
				continue;
			}
			if (bl) {
				rows.add(currentRow);
			}
		}
		return rows;


	}

	/**
	 * 返回符合过滤条件的数据行集合,并返回
	 * param filterString 过滤字符串,例如  a>1 and a>=2 or a<3 and a<=4 or a!=5 and a=6 or a!='b' and a='c'
	 * @return 过滤后的 List<DataRow>
	 */
	public List<DataRow> selectx(String filterString) {
		List<DataRow> rows = new ArrayList<DataRow>();
		if (DataType.IsNullOrEmpty(filterString) == true)
			return rows;

		boolean bl = false;
		for (Object row : Rows) {
			DataRow currentRow = (DataRow) row;
			try {
				//bl = dataRowCompute(filterString, currentRow);
				if(filterString.split("=").length>1)
					bl = currentRow.getValue(filterString.split("=")[0].trim()).equals(filterString.split("=")[1].trim());
			} catch (Exception e) {
				System.err.println("语法错误");
				e.printStackTrace();
				continue;
			}
			if (bl) {
				rows.add(currentRow);
			}
		}
		return rows;


	}

	/**
	 * 数据行计算,是否符合filterString过滤条件
	 * param filterString 过滤条件,支持  and or > >= < <= != = 操作符,暂不支持括号
	 * param row 数据行
	 * @return true 符合
	 */
	private boolean dataRowCompute(String filterString, DataRow row){
		if (filterString == null || row == null){
			return false;
		}
		boolean orResult = false;
		try {
			String[] or = filterString.split(" (?i)or ");	// 忽略大小写
			for (String o : or){
				boolean andResult = true;
				String[] and = o.split(" (?i)and ");	// 忽略大小写
				for (String a : and){
					String[] kv = null;
					if (a.contains(">=")){
						kv = a.split(">=");
					}else if (a.contains(">")){
						kv = a.split(">");
					}else if (a.contains("<=")){
						kv = a.split("<=");
					}else if (a.contains("<")){
						kv = a.split("<");
					}else if (a.contains("!=")){
						kv = a.split("!=");
					}else if (a.contains("=")){
						kv = a.split("=");
					}


					if (kv != null && kv.length == 2){
						String key = kv[0].trim(), value = kv[1].trim();
						if (key != null && value != null){
							Object val = row.getValue(key);
							// is null
							if (value.equalsIgnoreCase("is null")){
								if (!(val == null)){
									andResult = false;
									break;
								}
							}
							// is not null
							else if (value.equalsIgnoreCase("is not null")){
								if (!(val != null)){
									andResult = false;
									break;
								}
							}
							// is string
							else if (value.startsWith("'") && value.endsWith("'")){
								String v = value.replaceAll("'", "");
								if (a.contains("!=")){
									if (!(!val.toString().equalsIgnoreCase(v))){
										andResult = false;
										break;
									}
								}else if (a.contains("=")){
									if (!(val.toString().equalsIgnoreCase(v))){
										andResult = false;
										break;
									}
								}
							}
							// is number
							else{
								int v =  Integer.parseInt(value.toString());
								int dbVal = Integer.parseInt(val.toString());
								if (a.contains(">=")){
									if (!(dbVal >= v)){
										andResult = false;
										break;
									}
								}else if (a.contains(">")){
									if (!(dbVal > v)){
										andResult = false;
										break;
									}
								}else if (a.contains("<=")){
									if (!(dbVal <= v)){
										andResult = false;
										break;
									}
								}else if (a.contains("<")){
									if (!(dbVal < v)){
										andResult = false;
										break;
									}
								}else if (a.contains("!=")){
									if (!(dbVal != v)){
										andResult = false;
										break;
									}
								}else if (a.contains("=")){
									if (!(dbVal == v)){
										andResult = false;
										break;
									}
								}
							}
						}
					}
				}
				// 如果有一个and成立,则成立。
				if (andResult){
					orResult = true;
					break;
				}
			}
		} catch (Exception e) {
			System.err.println("语法错误");
			e.printStackTrace();
		}
		return orResult;
	}

	public String getTableName() {
		return TableName;
	}



	public void setTableName(String tableName) {
		TableName = tableName;
	}

	/**
	 * 把DataTable當做二維陣列,給列索引和行名稱,取得值的方法 <br/>
	 * (發佈者自行寫的方法)
	 *
	 * param rowIndex 列索引(從0算起)
	 * param columnName 行名稱
	 * @return 回傳該位置的值
	 */
	public Object getValue(int rowIndex, String columnName)
	{
		return this.Rows.get(rowIndex).getValue(columnName);
	}

	public DataRow[] Select(String string) {
		DataRow[] dataRowsx = null;
		List<DataRow> dataRowList = new ArrayList<DataRow>();
		if (DataType.IsNullOrEmpty(string)==false) {
			boolean bl;
			for (Object row : Rows) {
				DataRow currentRow = (DataRow) row;
				try {
					bl = dataRowCompute(string, currentRow);
				} catch (Exception e) {
					System.err.println("语法错误");
					e.printStackTrace();
					continue;
				}
				if (bl) {
					dataRowList.add(currentRow);
				}
			}
			dataRowsx = new DataRow[dataRowList.size()];
			for(int i=0;i<dataRowList.size();i++){
				dataRowsx[i] = dataRowList.get(i);
			}
			return dataRowsx;

		} else {
			return dataRowsx;
		}
	}


	public void WriteXml(String path, DataTable dt) {
		StringBuilder str = new StringBuilder("<?xml version=\"1.0\" standalone=\"yes\"?>");
		str.append("<DataTable>");
		for (int k = 0; k < dt.Rows.size(); k++) {
			str.append("<");
			str.append(dt.getTableName());
			str.append(">");
			for (int j = 0; j < dt.Columns.size(); j++) {
				DataColumn dc = dt.Columns.get(j);

				str.append("<");
				str.append(dc.ColumnName);
				str.append(">");
				try {
					Object value = dt.Rows.get(k).getValue(dc);
					if (value.toString().contains(">") || value.toString().contains("<") || value.toString().contains("&")
							|| value.toString().contains("'") || value.toString().contains("\"")) {
						value = value.toString().replace(">", "&gt;");
						value = value.toString().replace("<", "&lt;");
						value = value.toString().replace("&", "&amp;");
						value = value.toString().replace("'", "&apos;");
						value = value.toString().replace("\"", "&quot;");
					}
					str.append(value);
				} catch (Exception e) {

				}
				str.append("</");
				str.append(dc.ColumnName);
				str.append(">");

			}
			str.append("</");
			str.append(dt.getTableName());
			str.append(">");
		}
		str.append("</DataTable>");
		// }
		String temp = str.toString();
		// String temp = formatXml(str.toString());

		// 写入文件
		File file = new File(path);
		try {
			if (!file.exists()) {
				file.createNewFile();
			}
			FileOutputStream fos = new FileOutputStream(file);
			OutputStreamWriter osw = new OutputStreamWriter(fos, "utf-8");
			BufferedWriter br = new BufferedWriter(osw);
			br.write(temp.toString());
			fos.flush();
			br.close();
			fos.close();
			osw.close();

		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	/**
	 * 获取文件的XML文件内容。
	 * param path xml文件路径
	 * @return xml文件内容
	 */
	public String xmlToString(String path) throws Exception {
		String line = null;
		StringBuffer strBuffer = new StringBuffer();
		int pathType =0;
		if(path.indexOf("DataUser/")!=-1 || path.indexOf("WF/")!=-1)
			pathType =1;
		try {
			String encoding = "UTF-8"; // 字符编码
			if(SystemConfig.getIsJarRun() && pathType==1){
				ClassPathResource classPathResource = new ClassPathResource(path);
				InputStream inputStream = classPathResource.getInputStream();
				StringBuilder stringBuilder = new StringBuilder();
				BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream, encoding));
				StringBuffer buffer = new StringBuffer();
				while ((line = bufferedReader.readLine()) != null){
					buffer.append(line + "\n");
				}
				bufferedReader.close();
				return buffer.toString();
			}else{
				File file = new File(path);
				if (file.isFile() && file.exists()) {

					InputStreamReader read = new InputStreamReader(new FileInputStream(file), encoding);
					BufferedReader bufferedReader = new BufferedReader(read);
					while ((line = bufferedReader.readLine()) != null) {
						strBuffer.append(line + "\n");
					}
					read.close();
				} else {
					throw new Exception("找不到指定的文件"+path+",请联系管理员查看环境配置是否正确,jflow.properties中的配置是否正确");
				}
			}

		} catch (Exception e) {
			throw new Exception("读取文件内容操作出错!" + e.getMessage());
		}
		return strBuffer.toString();
	}
	public boolean iscontains(List<DataColumn> dcList, String column) {
		for (DataColumn dc : dcList) {
			if (dc.ColumnName.equals(column)) {
				return true;
			}
		}
		return false;
	}
	/**
	 * 读取XML文件
	 * param xmlpath xml文件路径
	 * @author ThinkGem
	 */
	@SuppressWarnings("rawtypes")
	public DataTable readXml(String xmlpath) {
		if (DataType.IsNullOrEmpty(xmlpath)){
			return null;
		}
		try {
			String xml = xmlToString(xmlpath);
			Document document = new SAXReader().read(new ByteArrayInputStream(xml.getBytes("UTF-8")));
			Element root = document.getRootElement();
			DataTable dt = new DataTable(root.getName());
			DataRow dr = null;
			for (Iterator i = root.elementIterator(); i.hasNext();){
				Element element = (Element) i.next();
				dr = dt.NewRow();
				// 遍历该DataTable的属性
				for (Iterator it = element.attributeIterator(); it.hasNext();) {
					Attribute at = (Attribute)it.next();
//					System.out.println(" ======= " + at.getName());
					//sunxd 修改
					//由于"at.getName().toLowerCase()"语句导至  isContains 方法判断永远不成立,会给TABLE插入很多重复列
					//将at.getName().toLowerCase() 修改为  at.getName()
					if (!iscontains(dt.Columns.subList(0, dt.Columns.size()), at.getName())) {
						dt.Columns.Add(at.getName());
					}
					dr.setValue(at.getName(), at.getValue());
				}

				// 遍历该DataTable的子元素
				for (Iterator it = element.elementIterator(); it.hasNext();) {
					Element at = (Element) it.next();

					if (!iscontains(dt.Columns.subList(0, dt.Columns.size()), at.getName())) {
						dt.Columns.Add(at.getName());
					}
					String value = at.getText();
					try {
						//导出模板进行了转义,现在进行反转 dgq 2018-7-5
						if (value.toString().contains("&gt;") || value.toString().contains("&lt;")
								|| value.toString().contains("&amp;") || value.toString().contains("&apos;")
								|| value.toString().contains("&quot;")) {
							value = value.toString().replace("&amp;", "&");
							value = value.toString().replace("&gt;",">");
							value = value.toString().replace("&lt;","<");
							value = value.toString().replace("&apos;","'");
							value = value.toString().replace("&quot;","\"");
						}
					} catch (Exception e) {

					}
					dr.setValue(at.getName(), value);
				}
				dt.Rows.add(dr);
			}


			return dt;
		} catch (Exception e) {
			e.printStackTrace();
		}
		return null;
	}

}

参考资料和推荐阅读

  1. 暂无

欢迎阅读,各位老铁,如果对你有帮助,点个赞加个关注呗!~
如有侵权,请联系删除之

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/164419.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue实战第1章:学习和使用vue-router

学习和使用vue-router 前言 本篇在讲什么 简单讲解关于vue-router的使用 仅介绍简单的应用&#xff0c;仅供参考 本篇适合什么 适合初学Vue的小白 适合想要自己搭建网站的新手 适合没有接触过vue-router的前端程序 本篇需要什么 对Html和css语法有简单认知 对Vue有…

2023/1/14 js基础学习

1 js基础学习-基本数据类型基本语法 请参考 https://blog.csdn.net/m0_48964052?typeblog https://gitee.com/hongjilin/hongs-study-notes/blob/master/%E7%BC%96%E7%A8%8B_%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/HTMLCSSJS%E5%9F%BA%E…

Arthas 入门到实战(二)在线热更新

1. 结合 jad/mc 命令在线修改使用 jad 命令: 将 JVM 中实际运行的 class 的 byte code 反编译成 java 代码&#xff0c;便于你理解业务逻辑&#xff1b; mc命令&#xff1a;Memory Compiler/内存编译器&#xff0c;编译.java文件生成.class。 redefine命令&#xff1a;加载…

unix进程控制及进程环境--自APUE

文章目录概述1、孤儿进程和僵尸进程进程终止进程的编译和启动进程终止的步骤进程8种终止方式进程退出函数1&#xff1a;exit进程退出函数2&#xff1a;_exit进程退出函数3&#xff1a;_Exit注册终止处理程序&#xff1a;atexit环境变量通过main函数传参全局的环境变量表&#x…

uni-app跨端自定义指令实现按钮权限

前言 初看这个标题可能很迷&#xff0c;uni-app明明不支持自定义指令&#xff0c;这文章是在搞笑吗&#xff0c;本文对于uni-app自定义指令实现按钮权限的方式也有可能是多余&#xff0c;但为了给业务部门更友好的开发体验&#xff0c;还是做了一些可能没意义的操作&#xff0…

回顾2022,展望 2023

个人相关&#xff1a; PMP 因为疫情多次延期的PMP终于搞定&#xff0c;光环的PMP就是妥妥。基本只要认真做题和思考都会过。但是考试不仅仅是考试&#xff0c;有时候更多的是对项目发展和项目管理的思考&#xff1a;风险&#xff0c;里程碑&#xff0c;相关方&#xff0c;敏捷&…

红日内网渗透靶场2

目录 环境搭建&#xff1a; Web渗透&#xff1a; weblogic漏洞利用 java反序列化漏洞利用、哥斯拉获取shell 上线msf msf派生shell到cs 内网信息收集 mimikatz获取用户密码 cs横向移动 PTT攻击&#xff08;票据传递&#xff09; 方法2&#xff1a;通过msf利用永恒之蓝…

测试之分类【测试对象、是否查看代码、开发】

文章目录1. 按测试对象分类2. 按照是否查看代码划分3. 按照开发阶段划分1. 按测试对象分类 可靠性测试容错性测试安装卸载测试内存泄露测试弱网测试 &#xff08;1&#xff09;可靠性测试 可靠性 正常运行时间 / (正常运行时间 非正常运行时间) * 100% &#xff08;最高 10…

Servlet的实战用法(表白墙前后端)

作者&#xff1a;~小明学编程 文章专栏&#xff1a;JavaEE 格言&#xff1a;热爱编程的&#xff0c;终将被编程所厚爱。 目录 服务器版本的表白墙 创建项目 约定前后端交互接口 获取全部留言 发表新的留言 服务端代码 创建Message类 创建DBUtil类 创建MessageServlet…

双指针合集

87合并两个有序的数组 import java.util.*; public class Solution {public void merge(int A[], int m, int B[], int n) { int i m-1;int j n-1;for(int k nm-1;k>0;k--){if(j<0) A[k] A[i--];else if(i<0) A[k] B[j--];else if(A[i]>B[j]) A[k] A[i--]…

六道数据结构算法题详解

目录 1.力扣350题. 两个数组的交集 II 2.力扣121题. 买卖股票的最佳时机 3.力扣566题. 重塑矩阵 4.力扣118题. 杨辉三角 5.牛客BM13 判断一个链表是否为回文结构 6.牛客BM14 链表的奇偶重排 1.力扣350题. 两个数组的交集 II 题目&#xff1a;给你两个整数数组 nums1 和 n…

2022年终总结---权衡好工作和生活

2022总结 【校园】2022年6月研究生顺利毕业&#xff0c;让下文的一切才变的有机会。感谢师弟送学长毕业&#xff0c;感谢在最后时刻各位舍友帮忙送材料&#xff0c;怀念最后一个月一起打球的时光。 【工作】2022年6月入职阿里&#xff0c;成为打工人。在这个大的平台&#xf…

Goland项目使用gomod配置

Goland 项目创建 goland2020.3 及以上 IDE&#xff0c;默认创建的 go 项目 就是使用 gomod 管理&#xff01; goland2020.3 及以下的 IDE&#xff0c;创建项目时需要选择 带小括号 vgo 的才是 gomod 管理模式 下图为使用 goland2021.3 版本创建使用 gomod 管理的 go 项目&…

14种可用于时间序列预测的损失函数

在处理时间序列预测问任务时&#xff0c;损失函数的选择非常重要&#xff0c;因为它会驱动算法的学习过程。以往的工作提出了不同的损失函数&#xff0c;以解决数据存在偏差、需要长期预测、存在多重共线性特征等问题。本文工作总结了常用的的 14 个损失函数并对它们的优缺点进…

线段树(Segment tree)

线段树 线段树是一种二叉树形数据结构,用以储存区间或线段,并且允许快速查询结构内包含某一点的所有区间。 视频讲解 线段树主要实现两个方法:「求区间和」&「修改区间」,且时间复杂度均为 O(logn)。 nums = [1, 2, 3, 4, 5] 对应的线段树如下所示: 使用数组表示线段…

【阶段三】Python机器学习33篇:机器学习项目实战:医学病症关联规则分析

本篇的思维导图: 医学病症关联规则分析 项目背景 本项目演示一个医学领域的有趣应用——病症关联规则分析,同时利用apyori库和mlxtend库来编写代码,从数据分析的角度去研究病症背后的关联规则。假设有一种医学理论认为,五脏和一些病症之间存在关联关系,见下表。例…

4.线性神经网络

4.线性神经网络 目录 线性回归 线性回归的基本元素 线性模型损失函数解析解随机梯度下降 矢量化加速正态分布与平方损失 优化方法 梯度下降选择学习率小批量随机梯度下降选择批量大小总结 线性回归的从零开始实现 生成数据集读取数据集初始化模型参数定义模型定义损失函数定义…

磨金石教育摄影技能干货分享|优秀摄影作品欣赏——世界掠影

这世上很多地方都在发生着有趣的事&#xff0c;很多地方不同的人与物&#xff0c;都在不同的时间和环境下展现着不同的状态。让我们跟随摄影师的镜头去欣赏这些精彩的画面吧。1 悬而未定想象一下这张照片是什么角度拍的&#xff1f;是不是看上去很像俯拍&#xff1f;无论怎么看…

【Python】groupby操作后不把列作为索引单独提出

这是一个困了我几天的问题。 一开始的搜索方向错了&#xff0c;按照groupby的key column搜索&#xff0c;没有搜到。 最近悟出的一个技巧是&#xff0c;没有头绪时看看数据类型和数据内容。如果思路是没问题的情况下。 问题描述 date_date.groupby([XXXX]) poi_date.groupby(…

可视化工具,Java 应用性能分析、调优

JVisualVM 简介 VisualVM 是Netbeans的profile子项目&#xff0c;已在JDK6.0 update 7 中自带&#xff0c;能够监控线程&#xff0c;内存情况&#xff0c;查看方法的CPU时间和内存中的对 象&#xff0c;已被GC的对象&#xff0c;反向查看分配的堆栈(如100个String对象分别由哪…