【转】用Java生成HTML文件

实现搜索引擎功能时,HTML存于MySQL中,因此实现快照功能需要新建HTML页面(至少第一次需要新建)。

 

http://blog.csdn.net/zhanghaotian2011/article/details/11575397

原理跟用java生成jsp的servlet差不多。我们可以用printStream来向html文件里输出数据。

先创建一个StringBuilder对象,通过append方法来为其添加html语句。如下面例子所示:

 

[java] view plaincopy
 
  1. StringBuilder sb = new StringBuilder();  
  2.         Properties fileProperties = getProperties("file");  
  3.         Properties sqlProperties = getProperties("sql");  
  4.         PrintStream printStream = new PrintStream(new FileOutputStream(  
  5.                 "report.html"));  
  6.         sb.append("<html>");  
  7.         sb.append("<head>");  
  8.         sb.append("<title>每日运营报表</title>");  
  9.         sb.append("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\" />");  
  10.         sb.append("<style type=\"text/css\">");  
  11.         sb.append("TABLE{border-collapse:collapse;border-left:solid 1 #000000; border-top:solid 1 #000000;padding:5px;}");  
  12.         sb.append("TH{border-right:solid 1 #000000;border-bottom:solid 1 #000000;}");  
  13.         sb.append("TD{font:normal;border-right:solid 1 #000000;border-bottom:solid 1 #000000;}");  
  14.         sb.append("</style></head>");  
  15.         sb.append("<body bgcolor=\"#FFF8DC\">");  
  16.         sb.append("<div align=\"center\">");  
  17.         sb.append("<br/>");  
  18.         sb.append("<br/>");  
  19.         List<Map<String, Object>> result1 = getRpt(sqlProperties  
  20.                 .getProperty("sql1"));  
  21.         for (Map.Entry<String, Object> m : result1.get(0).entrySet()) {  
  22.             sb.append(fileProperties.getProperty("file1"));  
  23.             sb.append(m.getValue());  
  24.         }  
  25.         sb.append("<br/><br/>");  

输出的话,也很简单。

[java] view plaincopy
 
  1. sb.append("</div></body></html>");  
  2.         printStream.println(sb.toString());  

再上传一张我用java生成的一个测试html,还没有调用线上数据。大家在实际应用的时候可以利用sql语句,list来填充表格。

下面给一个我写的例子

 

[java] view plaincopy
 
  1. sb.append("<table border=\"1\"><tr>");  
  2.         for (Map.Entry<String, Object> m : result.get(0).entrySet()) {  
  3.             sb.append("<th>");  
  4.             sb.append(m.getKey());  
  5.             sb.append("</th>");  
  6.         }  
  7.         sb.append("</tr>");  
  8.         for (int i = 0; i < result.size(); i++) {  
  9.             sb.append("<tr>");  
  10.             for (Map.Entry<String, Object> m : result.get(i).entrySet()) {  
  11.                 sb.append("<td>");  
  12.                 sb.append(m.getValue());  
  13.                 sb.append("</td>");  
  14.             }  
  15.             sb.append("</tr>");  
  16.         }  
  17.         sb.append("</table>");  

故事就是这样。下集更精彩~

posted @ 2015-07-07 16:17  MERRU  阅读(862)  评论(0)    收藏  举报