根据己有的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>

相关推荐