根据己有的word或excel文件样式输出报表
.根据己有的word或excel文件样式输出报表(转自《灰灰虫的家》)
实现思路:在服务器端建立一个Word或Excel文档,文档中加入书签,然后把要添写的内容写入标签中.
(1)创建一个Word文档,在该文档中设计好要打印的会议记录的格式,并将其保存到实例根目录下,名称为student.doc。
(2)在创建好的Word文档中的指定位置插入书签。插入书签首先选中需要替换的文本,然后选择“插入”→“书签”选项,在打开的对话框中输入书签名,并单击“添加”按钮即可。
(3)编写自定义JavaScript函数,用于将表单收集的数据导出到Word中,并进行自动打印,代码如下:
服务器端
protectedvoidPage_Load(objectsender,EventArgse)
{
stringstr=Request.Url.ToString();
strings=str.Substring(0,str.LastIndexOf("/"));
//将当前页面的父路径存入Hidden中
this.Hidden1.Value=s+"/";
}
客户端
<htmlxmlns="http://www.w3.org/1999/xhtml">
<headrunat="server">
<title>无标题页</title>
<scriptlanguage="javascript"type="text/javascript">
functionButton1_onclick(){
//取出Hidden中的内容
varss=document.form1.Hidden1.value;
//创建word应用程序对象
varwordapp=newActiveXObject("word.application");
//显示word应用程序窗口
wordapp.visible=true;
//设置word文件模板的路径
vars=ss+"student.doc";
//打开要填写的模板
varworddoc=wordapp.application.documents.open(s);
varrange;
//取出word中相应的书签,并把页面文本框中的内容替换进去
range=wordapp.activedocument.Bookmarks("sname").Range;
range.text=document.form1.txtName.value;
range=wordapp.activedocument.bookmarks("sage").range;
range.text=document.form1.txtAge.value;
range=wordapp.activedocument.bookmarks("sschool").range;
range.text=document.form1.txtSchool.value;
wordapp.activedocument.printout();
//关闭word文档
wordapp.activedocument.close(0);
//关闭word应用程序
wordapp.quit();
}
</script>
</head>
<body>
<formid="form1"runat="server">
<div>
姓名:<asp:TextBoxid="txtName"runat="server"></asp:TextBox>
<br/>
年龄:<asp:TextBoxid="txtAge"runat="server"></asp:TextBox>
<br/>
学校:<asp:TextBoxid="txtSchool"runat="server"></asp:TextBox>
<br/>
<inputid="Button1"type="button"value="ToBookMark"onclick="returnButton1_onclick()"/><inputrunat=serverid="Hidden1"name="Hidden1"type="hidden"/></div>
</form>
</body>
</html>