单位里的查询系统是基于struts的,在结果集显示的处理上都是用 <logic:iterate id=".." indexId="id" name=".." scope="request"> 然后在<bean:write name=".." property=".."> 这样子对付的,后来觉得比较麻烦,就写了一个显示结果集的标签
- 行记录用HashMap保存
- 结果集用Vector封装
- 表格的标题等属性用xml配置
- dom4j解析xml文件
- 输出时根据配置合并多行内的相同属性列
- 求和
表格配置文件table-config.xml保存在/WEB-INF下
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<?xml version="1.0" encoding="gb2312"?>
<table-config>
data:image/s3,"s3://crabby-images/84374/8437476b83531729029df2c7c5e65dc4db1051cf" alt=""
data:image/s3,"s3://crabby-images/84374/8437476b83531729029df2c7c5e65dc4db1051cf" alt=""
<table name="jcgl_dzjk" width="800">
<title>稽查数据电子缴库情况</title>
<groupby>id_wjdm</groupby>
<columns>
<column>
<name>id_wjdm</name>
<header>微机代码</header>
<width>60</width>
<bind>true</bind>
</column>
<column>
<name>name_nsr</name>
<header>单位名称</header>
<width>200</width>
<bind>true</bind>
</column>
<column>
<name>id_sz</name>
<header>税种</header>
<map>map_sz</map>
</column>
<column>
<name>id_sm</name>
<header>税目</header>
</column>
<column>
<name>ybtse</name>
<header>查补金额</header>
<width>100</width>
<sum>true</sum>
</column>
<column>
<name>date_sbbrq</name>
<header>申报日期</header>
</column>
<column>
<name>date_jkrq</name>
<header>扣款日期</header>
</column>
<column>
<name>kkzt</name>
<header>扣款状态</header>
</column>
</columns>
</table>
data:image/s3,"s3://crabby-images/84374/8437476b83531729029df2c7c5e65dc4db1051cf" alt=""
data:image/s3,"s3://crabby-images/84374/8437476b83531729029df2c7c5e65dc4db1051cf" alt=""
</table-config>
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
用于表格配置的Table.java
package tax.tags;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import java.util.Vector;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class Table
{
private String name;
private String width;
private String title;
private String groupby;
private Vector<Column> columns;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Table()
{
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Table(String name)
{
this.name=name;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Vector<Column> getColumns()
{
return columns;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setColumns(Vector<Column> columns)
{
this.columns = columns;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getName()
{
return name;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setName(String name)
{
this.name = name;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getTitle()
{
return title;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setTitle(String title)
{
this.title = title;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getWidth()
{
return width;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setWidth(String width)
{
this.width = width;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getGroupby()
{
return groupby;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setGroupby(String groupby)
{
this.groupby = groupby;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String toString()
{
StringBuffer buf=new StringBuffer();
buf.append("Name:").append(name).append("\n");
buf.append("Width:").append(width).append("\n");
buf.append("Title:").append(title).append("\n");
buf.append("Groupby:").append(groupby).append("\n");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(int i=0;i<columns.size();i++)
{
Column column=columns.elementAt(i);
buf.append("column name:").append(column.getName()).append("\n");
buf.append(" header:").append(column.getHeader()).append("\n");
buf.append(" width:").append(column.getWidth()).append("\n");
buf.append(" sum:").append(column.isSum()).append("\n");
buf.append(" bind:").append(column.isBind()).append("\n");
}
return buf.toString();
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
class Column
{
private String name;
private String width;
private String header;
private String map;
private boolean sum;
private boolean bind;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Column()
{
sum=false;
bind=false;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean isBind()
{
return bind;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setBind(boolean bind)
{
this.bind = bind;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getHeader()
{
return header;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setHeader(String header)
{
this.header = header;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getName()
{
return name;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setName(String name)
{
this.name = name;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean isSum()
{
return sum;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setSum(boolean sum)
{
this.sum = sum;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getWidth()
{
return width;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setWidth(String width)
{
this.width = width;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getMap()
{
return map;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setMap(String map)
{
this.map = map;
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
用dom4j解析table-config.xml的Dom4jTable.java,因为用到了xpath,所以把jaxen-1.1-beta-6.jar也要拷贝到/web-inf/lib里面去
package tax.tags;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import java.util.List;
import java.util.Vector;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class Dom4jTable
{
String tableName;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Dom4jTable()
{ }
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Dom4jTable(String tableName)
{
this.tableName = tableName;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Document parse(String xmlpath) throws DocumentException
{
SAXReader reader = new SAXReader();
Document doc = null;
doc = reader.read(xmlpath);
return doc;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Table getTable(Document doc)
{
Table table;
String xpath = "//table[@name='" + tableName + "']";
Node node = doc.selectSingleNode(xpath);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (node == null)
{
table = null;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
table = new Table(tableName);
table.setWidth(getValue(node,"@width"));
table.setTitle(getValue(node,"title"));
table.setGroupby(getValue(node,"groupby"));
Vector<Column> columns = new Vector<Column>();
Node nodeColumns = node.selectSingleNode("columns");
List list = ((Element) nodeColumns).elements();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < list.size(); i++)
{
Column column = new Column();
Element element = (Element) list.get(i);
column.setName(getValue(element,"name"));
column.setHeader(getValue(element,"header"));
column.setWidth(getValue(element,"width"));
column.setMap(getValue(element,"map"));
column.setBind(Boolean.parseBoolean(getValue(element,"bind")));
column.setSum(Boolean.parseBoolean(getValue(element,"sum")));
columns.add(column);
}
table.setColumns(columns);
}
return table;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private String getValue(Node node,String name)
{
String value=node.valueOf(name);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(value.equals(""))
{
value=null;
}
return value;
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
自定义标签ShowTableTag.java,写的有点乱,还好能用,本来用sax解析xml的,后来改为dom4j的
package tax.tags;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import java.math.BigDecimal;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.TreeMap;
import java.util.Vector;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.JspWriter;
import javax.servlet.jsp.tagext.TagSupport;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.XMLReaderFactory;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class ShowTableTag extends TagSupport
{
private static final long serialVersionUID = 1L;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
private Log log = LogFactory.getLog(this.getClass());
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
private String vectorName;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
private String tableName;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
private boolean displaySN = false;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
private Vector<HashMap> data = null;
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int doStartTag() throws JspException
{
return TagSupport.SKIP_BODY;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int doEndTag() throws JspException
{
String newline = "\n";
boolean getsum=false;
JspWriter out = pageContext.getOut();
StringBuffer buf = new StringBuffer();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (data == null || data.size() == 0)
{
buf.append("There is no result available.");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
// 取表格的各项属性设置
Table table = getTableConfigByDom4j();
// 取表格的各列,然后存入cols数组
Vector columns = table.getColumns();
Column[] cols=new Column[columns.size()];
BigDecimal[] sum=new BigDecimal[columns.size()];
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(int i=0;i<columns.size();i++)
{
cols[i]=(Column)columns.elementAt(i);
if(cols[i].isSum()) getsum=true;
sum[i]=new BigDecimal(0);
}
/////////////////////////////////////////////////////////////////////////////////////////
// 如果table没有设置title, 就不打印这部分
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(table.getTitle()!=null)
{
buf.append("<DIV id=tag_head><div class=label>").append(newline);
buf.append(table.getTitle()).append("</div></div><div id=tag_body>");
buf.append(newline);
}
buf.append("<div class=content>").append(newline);
buf.append("<table border=1 cellPadding=0 cellSpacing=0 ");
buf.append("borderColorLight=#000000 borderColorDark=#f8f7f5 width=\"");
buf.append(table.getWidth()).append("\">").append(newline);
buf.append("<tr class=tablehead>").append(newline);
// 如果标签中的displaySN为true, 则打印序号列
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (displaySN)
{
buf.append("<th>序号</th>").append(newline);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
// 打印table的th栏
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < cols.length; i++)
{
buf.append("<th");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (cols[i].getWidth() != null)
{
buf.append(" width=").append(cols[i].getWidth());
}
buf.append(">").append(cols[i].getHeader()).append("</th>");
buf.append(newline);
}
buf.append("</tr>").append(newline);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
// 由table的groupby属性产生key_group<Integer,Integer>
// 第一个Integer是行号,从1开始
// 第二个Integer是跨度span,即连续相同的key的数量
Hashtable key_group = getKeyGroup(table.getGroupby());
int rowid = 0; //行号
int distid = 0; //捆绑相同key行后的行号
Iterator<HashMap> it = data.iterator();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (it.hasNext())
{
buf.append("<tr class=tablepad>").append(newline);
rowid++;
// 根据行号从key_group中取得pan值, span可能为null
Integer span=(key_group==null?null:(Integer)key_group.get(new Integer(rowid)));
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
// 显示序号
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (displaySN)
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(key_group==null)
{
//key_group为null表示table中不用合并相同的行
buf.append("<td>").append(rowid).append("</td>");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
}else if(span!=null)
{
buf.append("<td rowspan=").append(span).append(">");
buf.append(++distid).append("</td>").append(newline);
}
}
// 取得这一行的记录
HashMap row = (HashMap)it.next();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < cols.length; i++)
{
// 取得td中应该显示的内容
String td = (String) row.get(cols[i].getName());
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(cols[i].isSum())
{
sum[i]=sum[i].add(new BigDecimal(td));
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(cols[i].getMap()!=null)
{
TreeMap map = (TreeMap) pageContext.getServletContext()
.getAttribute(cols[i].getMap());
td=(String)map.get(td);
}
if (td == null) td = " ";
// 区别这个列的bind属性确定是否要合并显示
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(!cols[i].isBind()||key_group==null)
{
buf.append("<td>");
buf.append(td).append("</td>").append(newline);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
}else if(span!=null)
{
buf.append("<td rowspan=").append(span).append(">");
buf.append(td).append("</td>").append(newline);
}
}
buf.append("</tr>").append(newline);
}
//如果需要打印合计数,增加一行
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(getsum)
{
buf.append("<tr class=tablepad>");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(displaySN)
{
buf.append("<td> </td>");
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(int i=0;i<cols.length;i++)
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(cols[i].isSum())
{
buf.append("<td>").append(sum[i]).append("</td>").append(newline);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
}else
{
buf.append("<td> </td>").append(newline);
}
}
buf.append("</tr>").append(newline);
}
buf.append("</table>").append(newline);
buf.append("</div></div>");
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
out.println(buf.toString());
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
log.error("e");
return TagSupport.SKIP_PAGE;
}
return TagSupport.EVAL_PAGE;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private Hashtable getKeyGroup(String key)
{
if(key==null) return null;
// 返回Hashtable, 键-从1开始的行号. 值-从这行开始连续的rowspan值.
Hashtable<Integer, Integer> ht = new Hashtable<Integer, Integer>();
Iterator it = data.iterator();
int count = 0;
int start = 0;
int current = 0;
String value = "", prevalue = "";
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (it.hasNext())
{
current++;
HashMap row = (HashMap) it.next();
value = (String) row.get(key);
if (value.equals(prevalue))
count++;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
else
{
ht.put(new Integer(start),new Integer(count));
prevalue = value;
count = 1;
start=current;
}
}
ht.put(new Integer(start),new Integer(count));
ht.remove(new Integer(0));
return ht;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private Table getTableConfigBySax()
{
Table table = null;
SaxTable sax = new SaxTable();
sax.setTableName(tableName);
String xmlfile = pageContext.getServletContext().getRealPath(
"WEB-INF/table-config.xml");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
XMLReader xdr = XMLReaderFactory
.createXMLReader("org.apache.xerces.parsers.SAXParser");
xdr.setContentHandler(sax);
xdr.parse(xmlfile);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
log.error(e);
}
table = sax.getTable();
return table;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private Table getTableConfigByDom4j()
{
Dom4jTable dt = new Dom4jTable(tableName);
Document doc = null;
String xmlPath = pageContext.getServletContext().getRealPath(
"WEB-INF/table-config.xml");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
doc = dt.parse(xmlPath);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (DocumentException e)
{
log.error(e);
return null;
}
Table table = dt.getTable(doc);
return table;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getTableName()
{
return this.tableName;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setTableName(String tableName)
{
this.tableName = tableName;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getVectorName()
{
return this.vectorName;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setVectorName(String vectorName)
{
this.vectorName = vectorName;
Object o = pageContext.getRequest().getAttribute(vectorName);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (o != null)
{
data = (Vector<HashMap>) o;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
data = null;
}
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setDisplaySN(boolean sn)
{
displaySN = sn;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean isDisplaySN()
{
return displaySN;
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
在标签库app.tld中的这一段tag定义
<tag>
<name>showTable</name>
<tagclass>tax.tags.ShowTableTag</tagclass>
<bodycontent>empty</bodycontent>
<info>
extract the date from a vector and present date in table
</info>
<attribute>
<name>vectorName</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>tableName</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>displaySN</name>
<required>false</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
最后就可以在jsp文件中使用了,例如:
<app:showTable tableName="jcgl_dzjk" vectorName="data" displaySN="true"/>
还没有在标签里做分页的处理,以后在加工吧