把页面里面表格数据以word模板下载下来怎么弄!

须莫有 2014-07-21 09:30:36
我用公司的方法实现了!但是只能下载一条数据,多条就不行了
老人告诉我把一条数据一个WORD然后压缩打包在下载!....我觉得不是很好求大神们指点怎么一次性把多条数据一起下载下来!
下面是我一条数据的下载方法

/**
* 文档下载
*/
public void exportWord() throws UIException {
try {
Houseapplydateit houseapplydateit = new Houseapplydateit();
// 将form bean的值拷贝给value bean
CopyBeanProperty.copyProperties(houseapplydateit,
houseapplydateitForm);
List<Houseapplyupreportdateit> list = houseapplydateitForm
.getList();

if (houseapplydateit != null) {
Configuration configuration = new Configuration();
configuration.setDefaultEncoding("utf-8");
Map<String, Object> data = new Hashtable<String, Object>();
for (int i = 0; i < list.size(); i++) {
data.put("ID", list.get(i).getCompID().getApplyId());
data.put("YearBatch", houseapplydateit.getNoticeYear()
+ "年" + houseapplydateit.getNoticeBatch() + "批");
String name = ucAreaInfoBO.getUcAreaInfo(
list.get(i).getCommunityAreano()).getAreaname();
data.put("Areaname", name);
name = ucAreaInfoBO.getUcAreaInfo(
list.get(i).getVillageAreano()).getAreaname();
data.put("villageAreano", name);
data.put("applyuserName", list.get(i).getApplyuserName());
data.put("familyValidUsernum", list.get(i)
.getFamilyValidUsernum());
data.put("nowhouseArea", list.get(i).getNowhouseArea());
data.put("demolishArea", list.get(i).getDemolishArea());
data.put("reformArea", list.get(i).getReformArea());
if (houseapplydateit.getUpreportStatus() == 1) {
if (list.get(i).getIsOk() == 1) {
data.put("isOk", "审批通过");
} else {
data.put("isOk", "审批不通过");
}
} else {
data.put("isOk", "街道未审批");
}

configuration.setClassForTemplateLoading(getClass(),
Config.getProperty("upreportTemplatePath"));
Template t = null;
t = configuration.getTemplate(Config
.getProperty("upreportTemplateFtl"));
t.setEncoding("gbk");
fileName = houseapplydateit.getNoticeYear() + "年"
+ houseapplydateit.getNoticeBatch() + "批" + ".doc";
this.fileName = new String(this.fileName.getBytes("GBK"),
"utf-8");
ActionContext ctx = ActionContext.getContext();
HttpServletResponse response = (HttpServletResponse) ctx
.get("com.opensymphony.xwork2.dispatcher.HttpServletResponse");
response.setContentType("application/msword");
response.addHeader("Content-Disposition",
"attachment; filename=" + fileName);
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
out.close();
}

}

} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

求指点!
...全文
221 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
须莫有 2014-07-21
  • 打赏
  • 举报
回复

function AllAreaWord()
{
	alert("ss");
 var oWD = new ActiveXObject("Word.Application");
 var oDC = oWD.Documents.Add("",0,1);
 var oRange =oDC.Range(0,1);
 var sel = document.body.createTextRange();
 sel.moveToElementText(PrintA);
 sel.select();
 sel.execCommand("Copy");
 oRange.Paste();
 oWD.Application.Visible = true;
 //window.close();
}
方法可以进入,但是到 var oWD = new ActiveXObject("Word.Application");时就运行不下去了!是不是什么文件没有导入???
须莫有 2014-07-21
  • 打赏
  • 举报
回复
引用 5 楼 shixitong 的回复:
[quote=引用 2 楼 Ghost_520 的回复:] 你说的这个直接用 js 做不可以么, 用 js 把表格提取出来, 然后 导出到 word 就可以了啊, 干嘛弄的这么麻烦啊, 你页面已经有了, 而且数据都在页面上
<HTML>
  <HEAD>
    <title>WEB页面导出为EXCEL文档的方法
    </title>
  </HEAD>
<body>
<BR>
<table id = "PrintA" width="100%" border="1" cellspacing="0" cellpadding="0" bgcolor = "#61FF13">
<TR style="text-align : center;">
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;"><font color="BLUE" face="Verdana">单元格合并行A</FONT></TD>
</TR>
</TABLE>
<BR>
<table id = "PrintB" width="100%" border="1" cellspacing="0" cellpadding="0">
<TR style="text-align : center;">
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;">单元格合并行B</TD>
</TR>
</TABLE>
<br><br><br>
<input type="button" onclick="javascript:AllAreaWord();" value="导出页面指定区域内容到Word">
<input type="button" onclick="javascript:AllAreaExcel();" value="导出页面指定区域内容到Excel">
<input type="button" onclick="javascript:CellAreaExcel();" value="导出表单单元格内容到Excel">
<SCRIPT LANGUAGE="javascript">
 //指定页面区域内容导入Excel
 function AllAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet;  
  var sel=document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oSheet.Paste();
  oXL.Visible = true;
 }
 //指定页面区域“单元格”内容导入Excel
 function CellAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet; 
  var Lenr = PrintA.rows.length;
  for (i=0;i<Lenr;i++) 
  { 
   var Lenc = PrintA.rows(i).cells.length; 
   for (j=0;j<Lenc;j++) 
   { 
    oSheet.Cells(i+1,j+1).value = PrintA.rows(i).cells(j).innerText; 
   } 
  } 
  oXL.Visible = true; 
 }

 //指定页面区域内容导入Word
 function AllAreaWord()
 {
  var oWD = new ActiveXObject("Word.Application");
  var oDC = oWD.Documents.Add("",0,1);
  var oRange =oDC.Range(0,1);
  var sel = document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oRange.Paste();
  oWD.Application.Visible = true;
  //window.close();
 }
</SCRIPT>
</body></html>
这个火狐或者chrome这些浏览器就不行了吧?[/quote] 我记得还要改游览器的某个选项吧!才可以用吧
shixitong 2014-07-21
  • 打赏
  • 举报
回复
引用 2 楼 Ghost_520 的回复:
你说的这个直接用 js 做不可以么, 用 js 把表格提取出来, 然后 导出到 word 就可以了啊, 干嘛弄的这么麻烦啊, 你页面已经有了, 而且数据都在页面上
<HTML>
  <HEAD>
    <title>WEB页面导出为EXCEL文档的方法
    </title>
  </HEAD>
<body>
<BR>
<table id = "PrintA" width="100%" border="1" cellspacing="0" cellpadding="0" bgcolor = "#61FF13">
<TR style="text-align : center;">
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;"><font color="BLUE" face="Verdana">单元格合并行A</FONT></TD>
</TR>
</TABLE>
<BR>
<table id = "PrintB" width="100%" border="1" cellspacing="0" cellpadding="0">
<TR style="text-align : center;">
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;">单元格合并行B</TD>
</TR>
</TABLE>
<br><br><br>
<input type="button" onclick="javascript:AllAreaWord();" value="导出页面指定区域内容到Word">
<input type="button" onclick="javascript:AllAreaExcel();" value="导出页面指定区域内容到Excel">
<input type="button" onclick="javascript:CellAreaExcel();" value="导出表单单元格内容到Excel">
<SCRIPT LANGUAGE="javascript">
 //指定页面区域内容导入Excel
 function AllAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet;  
  var sel=document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oSheet.Paste();
  oXL.Visible = true;
 }
 //指定页面区域“单元格”内容导入Excel
 function CellAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet; 
  var Lenr = PrintA.rows.length;
  for (i=0;i<Lenr;i++) 
  { 
   var Lenc = PrintA.rows(i).cells.length; 
   for (j=0;j<Lenc;j++) 
   { 
    oSheet.Cells(i+1,j+1).value = PrintA.rows(i).cells(j).innerText; 
   } 
  } 
  oXL.Visible = true; 
 }

 //指定页面区域内容导入Word
 function AllAreaWord()
 {
  var oWD = new ActiveXObject("Word.Application");
  var oDC = oWD.Documents.Add("",0,1);
  var oRange =oDC.Range(0,1);
  var sel = document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oRange.Paste();
  oWD.Application.Visible = true;
  //window.close();
 }
</SCRIPT>
</body></html>
这个火狐或者chrome这些浏览器就不行了吧?
须莫有 2014-07-21
  • 打赏
  • 举报
回复
引用 2 楼 Ghost_520 的回复:
你说的这个直接用 js 做不可以么, 用 js 把表格提取出来, 然后 导出到 word 就可以了啊, 干嘛弄的这么麻烦啊, 你页面已经有了, 而且数据都在页面上
<HTML>
  <HEAD>
    <title>WEB页面导出为EXCEL文档的方法
    </title>
  </HEAD>
<body>
<BR>
<table id = "PrintA" width="100%" border="1" cellspacing="0" cellpadding="0" bgcolor = "#61FF13">
<TR style="text-align : center;">
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;"><font color="BLUE" face="Verdana">单元格合并行A</FONT></TD>
</TR>
</TABLE>
<BR>
<table id = "PrintB" width="100%" border="1" cellspacing="0" cellpadding="0">
<TR style="text-align : center;">
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;">单元格合并行B</TD>
</TR>
</TABLE>
<br><br><br>
<input type="button" onclick="javascript:AllAreaWord();" value="导出页面指定区域内容到Word">
<input type="button" onclick="javascript:AllAreaExcel();" value="导出页面指定区域内容到Excel">
<input type="button" onclick="javascript:CellAreaExcel();" value="导出表单单元格内容到Excel">
<SCRIPT LANGUAGE="javascript">
 //指定页面区域内容导入Excel
 function AllAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet;  
  var sel=document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oSheet.Paste();
  oXL.Visible = true;
 }
 //指定页面区域“单元格”内容导入Excel
 function CellAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet; 
  var Lenr = PrintA.rows.length;
  for (i=0;i<Lenr;i++) 
  { 
   var Lenc = PrintA.rows(i).cells.length; 
   for (j=0;j<Lenc;j++) 
   { 
    oSheet.Cells(i+1,j+1).value = PrintA.rows(i).cells(j).innerText; 
   } 
  } 
  oXL.Visible = true; 
 }

 //指定页面区域内容导入Word
 function AllAreaWord()
 {
  var oWD = new ActiveXObject("Word.Application");
  var oDC = oWD.Documents.Add("",0,1);
  var oRange =oDC.Range(0,1);
  var sel = document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oRange.Paste();
  oWD.Application.Visible = true;
  //window.close();
 }
</SCRIPT>
</body></html>
这个我试试!不需要导入文件之类的吗?
须莫有 2014-07-21
  • 打赏
  • 举报
回复
引用 1 楼 shixitong 的回复:
上面的代码没看懂 Map<String, Object> data = new Hashtable<String, Object>(); 这个data在哪里使用? 而且这个data声明在for循环外面,那么不管怎么循环,最终肯定取的是最后一条(如果有数据),map中的key是不可以重复的,下载也写在循环里?
data 的key是跟WORD模板里面对应的。for循环可以无视掉!当初写的时候没有注意到这个!
Ghost_520 2014-07-21
  • 打赏
  • 举报
回复
你说的这个直接用 js 做不可以么, 用 js 把表格提取出来, 然后 导出到 word 就可以了啊, 干嘛弄的这么麻烦啊, 你页面已经有了, 而且数据都在页面上
<HTML>
  <HEAD>
    <title>WEB页面导出为EXCEL文档的方法
    </title>
  </HEAD>
<body>
<BR>
<table id = "PrintA" width="100%" border="1" cellspacing="0" cellpadding="0" bgcolor = "#61FF13">
<TR style="text-align : center;">
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
 <TD>单元格A</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;"><font color="BLUE" face="Verdana">单元格合并行A</FONT></TD>
</TR>
</TABLE>
<BR>
<table id = "PrintB" width="100%" border="1" cellspacing="0" cellpadding="0">
<TR style="text-align : center;">
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
 <TD>单元格B</TD>
</TR>
<TR>
 <TD colSpan=4 style="text-align : center;">单元格合并行B</TD>
</TR>
</TABLE>
<br><br><br>
<input type="button" onclick="javascript:AllAreaWord();" value="导出页面指定区域内容到Word">
<input type="button" onclick="javascript:AllAreaExcel();" value="导出页面指定区域内容到Excel">
<input type="button" onclick="javascript:CellAreaExcel();" value="导出表单单元格内容到Excel">
<SCRIPT LANGUAGE="javascript">
 //指定页面区域内容导入Excel
 function AllAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet;  
  var sel=document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oSheet.Paste();
  oXL.Visible = true;
 }
 //指定页面区域“单元格”内容导入Excel
 function CellAreaExcel() 
 {
  var oXL = new ActiveXObject("Excel.Application"); 
  var oWB = oXL.Workbooks.Add(); 
  var oSheet = oWB.ActiveSheet; 
  var Lenr = PrintA.rows.length;
  for (i=0;i<Lenr;i++) 
  { 
   var Lenc = PrintA.rows(i).cells.length; 
   for (j=0;j<Lenc;j++) 
   { 
    oSheet.Cells(i+1,j+1).value = PrintA.rows(i).cells(j).innerText; 
   } 
  } 
  oXL.Visible = true; 
 }

 //指定页面区域内容导入Word
 function AllAreaWord()
 {
  var oWD = new ActiveXObject("Word.Application");
  var oDC = oWD.Documents.Add("",0,1);
  var oRange =oDC.Range(0,1);
  var sel = document.body.createTextRange();
  sel.moveToElementText(PrintA);
  sel.select();
  sel.execCommand("Copy");
  oRange.Paste();
  oWD.Application.Visible = true;
  //window.close();
 }
</SCRIPT>
</body></html>
shixitong 2014-07-21
  • 打赏
  • 举报
回复
上面的代码没看懂 Map<String, Object> data = new Hashtable<String, Object>(); 这个data在哪里使用? 而且这个data声明在for循环外面,那么不管怎么循环,最终肯定取的是最后一条(如果有数据),map中的key是不可以重复的,下载也写在循环里?
须莫有 2014-07-21
  • 打赏
  • 举报
回复
引用 14 楼 Ghost_520 的回复:
[quote=引用 9 楼 pingfanpk 的回复:] [quote=引用 8 楼 Ghost_520 的回复:] [quote=引用 7 楼 pingfanpk 的回复:]

function AllAreaWord()
{
	alert("ss");
 var oWD = new ActiveXObject("Word.Application");
 var oDC = oWD.Documents.Add("",0,1);
 var oRange =oDC.Range(0,1);
 var sel = document.body.createTextRange();
 sel.moveToElementText(PrintA);
 sel.select();
 sel.execCommand("Copy");
 oRange.Paste();
 oWD.Application.Visible = true;
 //window.close();
}
方法可以进入,但是到 var oWD = new ActiveXObject("Word.Application");时就运行不下去了!是不是什么文件没有导入???
这是 IE 的写法额, 我是 IE8 什么设置都没做, 就可以运行出来, 你是用什么浏览器?[/quote] IE11[/quote] AciveXObject 是只有 IE 有的函数,不过从 IE9 后, IE内核就改变, 你在页面上设置下 META 信息在试试
<meta http-equiv="X-UA-Compatible" content="IE=7" >
<meta http-equiv="X-UA-Compatible" content="IE=edge" >
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" >
[/quote] 要到安全设置里面去该设置!
花木兰1闪21A 2014-07-21
  • 打赏
  • 举报
回复
看看docx4j html转word功能吧
Ghost_520 2014-07-21
  • 打赏
  • 举报
回复
引用 13 楼 liushenglan1 的回复:
[quote=引用 12 楼 Ghost_520 的回复:] [quote=引用 11 楼 liushenglan1 的回复:] 就是这种格式的
导入图片的部分要用 vba 来做, 把图片写入到 word 中, 可以网上搜搜, 有例子的[/quote] 找半天了都没找到一点实用一些的[/quote] http://www.baidu.com/index.php?tn=93046097_6_pg#tn=93046097_6_pg&wd=java%20%E5%AF%BC%E5%87%BA%E5%9B%BE%E7%89%87%E5%88%B0word&rsv_spt=1&issp=1&rsv_bp=0&ie=utf-8&rsv_sug3=12&rsv_sug4=1616&rsv_sug1=9&rsv_sug2=0&inputT=11982 资料一大堆啊
Ghost_520 2014-07-21
  • 打赏
  • 举报
回复
引用 9 楼 pingfanpk 的回复:
[quote=引用 8 楼 Ghost_520 的回复:] [quote=引用 7 楼 pingfanpk 的回复:]

function AllAreaWord()
{
	alert("ss");
 var oWD = new ActiveXObject("Word.Application");
 var oDC = oWD.Documents.Add("",0,1);
 var oRange =oDC.Range(0,1);
 var sel = document.body.createTextRange();
 sel.moveToElementText(PrintA);
 sel.select();
 sel.execCommand("Copy");
 oRange.Paste();
 oWD.Application.Visible = true;
 //window.close();
}
方法可以进入,但是到 var oWD = new ActiveXObject("Word.Application");时就运行不下去了!是不是什么文件没有导入???
这是 IE 的写法额, 我是 IE8 什么设置都没做, 就可以运行出来, 你是用什么浏览器?[/quote] IE11[/quote] AciveXObject 是只有 IE 有的函数,不过从 IE9 后, IE内核就改变, 你在页面上设置下 META 信息在试试
<meta http-equiv="X-UA-Compatible" content="IE=7" >
<meta http-equiv="X-UA-Compatible" content="IE=edge" >
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" >
liushenglan1 2014-07-21
  • 打赏
  • 举报
回复
引用 12 楼 Ghost_520 的回复:
[quote=引用 11 楼 liushenglan1 的回复:] 就是这种格式的
导入图片的部分要用 vba 来做, 把图片写入到 word 中, 可以网上搜搜, 有例子的[/quote] 找半天了都没找到一点实用一些的
Ghost_520 2014-07-21
  • 打赏
  • 举报
回复
引用 11 楼 liushenglan1 的回复:
就是这种格式的
导入图片的部分要用 vba 来做, 把图片写入到 word 中, 可以网上搜搜, 有例子的
liushenglan1 2014-07-21
  • 打赏
  • 举报
回复
就是这种格式的
liushenglan1 2014-07-21
  • 打赏
  • 举报
回复
有没有能导入图片的办法,就是数据表中有一列是图片,怎么导入word文档中去
须莫有 2014-07-21
  • 打赏
  • 举报
回复
引用 8 楼 Ghost_520 的回复:
[quote=引用 7 楼 pingfanpk 的回复:]

function AllAreaWord()
{
	alert("ss");
 var oWD = new ActiveXObject("Word.Application");
 var oDC = oWD.Documents.Add("",0,1);
 var oRange =oDC.Range(0,1);
 var sel = document.body.createTextRange();
 sel.moveToElementText(PrintA);
 sel.select();
 sel.execCommand("Copy");
 oRange.Paste();
 oWD.Application.Visible = true;
 //window.close();
}
方法可以进入,但是到 var oWD = new ActiveXObject("Word.Application");时就运行不下去了!是不是什么文件没有导入???
这是 IE 的写法额, 我是 IE8 什么设置都没做, 就可以运行出来, 你是用什么浏览器?[/quote] IE11
Ghost_520 2014-07-21
  • 打赏
  • 举报
回复
引用 7 楼 pingfanpk 的回复:

function AllAreaWord()
{
	alert("ss");
 var oWD = new ActiveXObject("Word.Application");
 var oDC = oWD.Documents.Add("",0,1);
 var oRange =oDC.Range(0,1);
 var sel = document.body.createTextRange();
 sel.moveToElementText(PrintA);
 sel.select();
 sel.execCommand("Copy");
 oRange.Paste();
 oWD.Application.Visible = true;
 //window.close();
}
方法可以进入,但是到 var oWD = new ActiveXObject("Word.Application");时就运行不下去了!是不是什么文件没有导入???
这是 IE 的写法额, 我是 IE8 什么设置都没做, 就可以运行出来, 你是用什么浏览器?
本DataGridView打印控件和.NET打印控件5.5版(含报表模板设计组件)2014年2月8日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB打印、C#打印都是可以的),有帮助文档与使用实例。 与上一版本的5.4版相比,新控件5.5版的主要更改如下: 1、对控件进行了完善,DGVPrint、VB2008Print、EasyReport组件的打印预览速度有较大的提升; 2、VB2008Print与EasyReport添加了二维码打印的功能,该功能使用开源的Zxing.NET实现; 3、添加了DrawDGVEx函数,一方面可以以DGVprint对象中的参数在VB2008Print组件中打印,另一方面提供了并排打印多个表格的重载函数; 4、DGVPrint组件添加了报表头与报表尾内容的设置属性和参数; 5、DGVPrint与VB2008Print组件在以工资条方式打印表格时,添加了是否自动换行续打的功能(即,如果工资条列太多在一行中打印不下时,可以指定自动换行续打); 6、修改了EasyReport组件的设计界面,每个区域的属性放在属性窗口中显示; 7、EasyReport组件添加了简单的多栏打印支持功能; 8、VB2008Print组件添加了PrintDGVFixedWidth函数,方便将DataGridView按指定宽度进行打印; 9、去掉了网页打印功能(因为在IE11下没法使用,所以干脆去掉),去掉了打印RDLC报表的功能; 10、其他一些完善,比如在导出Excel时,如果Columheader不可见,则不导出;解决了快速导出Excel时部分特殊列没有表格线问题(比如是数值列,但使用了%等格式);VB2008Print组件添加了PageScale可以指定打印时的缩放比例等等。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印)打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、强大的图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件中打印出来,也可以在Graphics对象中显示。 4、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 5、强大的文本打印输出功能,控件提供多个文本打印重载函数,打印文本时,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单倍或多倍行距打印文本。 6、强大的绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 7、支持同一文档多种版面格式打印(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边 距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 8、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 9、Excel导出功能,可以将DataGridView和GridView导出为Excel文件,5.2版控件还增加了不依赖Office的导出Excel功能,而且速度非常快,5.4版还增加了合并单元格的导出功能。 10、打印DataGridView时的打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或者从保存的打印方案文件中读取打印参数。 11、水印打印功能。根据需要,可以在页面中打印或不打印以半透明空心文字打印水印。 12、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 13、特殊文字效果打印功能。控件具有打印浮雕文字、阴影文字、空心文字、块文字的功能。 14、页眉页脚中既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 15、图像与图标打印输出功能。 16、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 17、自定义纸张支持功能。 18、纸张背景图片设置打印功能。 19、.NET4.0支持功能(是单独的一个文件) 20、直接打印窗口中的TreeView控件功能 21、打印窗口中的ListView功能。 22、RichTextBox控件的RTF文本打印功能。 23、斜线表头打印功能(5.4版新增)。 24、二维码打印功能(5.5版本增加)。 我将持续改进该控件,并将不断推出控件的新版本,要查看或下载控件的升级版本,请登陆网站:http://myyouping.download.csdn.net/ 。具体使用方法请参见帮助文件与实例文件,如有疑问或好的建议,请与我联系: 邮箱:myyouping@139.com Q Q:479781502

81,092

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧