`
free_xiang
  • 浏览: 52675 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

javascript导出页面表格为excel

    博客分类:
  • web
阅读更多
Javascript实现把网页中table的内容导入到excel中的几种方法

一、            直接拷贝整个表格到EXCEL中
二、            通过遍历表格,给EXCEL中相应的单元格赋值。
三、            把表格中的内容提取出来,利用IE的另存为.csv的格式。

各方法的好处:
1.      直接拷贝表格,能够保留表格中的原有的格式,比如,列,行的合并,对齐方式,底色等等,
2.      通过遍历表格,比较灵活,可以遍历表格某些需要部分的内容。
3.      利用IE的另存为,不用创建ActiveXObject对象,可以处理表格合并方面的问题。

各方法的缺点:
1.      可能弹出脚本错误:Automation不能创建对象。
解决方法:启用IE安全设置中的:对没有标记为安全的ActiveX控件进行初始化和脚本运行。
由于整个表格复制到EXCEL中,给表格加个标题,并加入到EXCEL中可能会遇到麻烦。
解决方法:首先在表格中加入第一行

<tr><td colspan="x" align="center">&</td></tr>
X,表示整个表格的列数,复制完整个表格后,加如下代码,oSheet为当前活动的sheet.
oSheet.Range(oSheet.Cells(1, 1), oSheet.Cells(1, x)).value = "表格标题";//设置标题
oSheet.Rows(1).Font.Size = 16;   //设置文字大小          
oSheet.Rows(1).Font.Name = "宋体";//设置文字字体
注:以下属性我没用着,可能有用,也可能会报错

oSheet.Range(oSheet.Cells(1,1), oSheet.Cells(1,14)).mergecells=true; //合并单元格
oSheet.Range(oSheet.Cells(1,1), oSheet.Cells(1,14)).Interior.ColorIndex=6;//设置底色?
oSheet.Range(oSheet.Cells(1,1), oSheet.Cells(1,14)).Font.ColorIndex=5;//设置字体色?
oSheet.Rows(1).RowHeight=20; //设置列高
oSheet.Cells(iRow,iCol).Halignment=’2’//设置字体居中

2.      可能弹出脚本错误:Automation不能创建对象(解决方法如上)。
表格内容写入到EXCEL中无表格线(未解决)
且有单元格合并时会有问题,解决方法:合并单元格后再写数据。

oSheet.Range(oSheet.Cells(1,1), oSheet.Cells(1,14)).mergecells=true; //合并单元格


3.      表格内容写入到EXCEL中无表格线(未解决)

表格格式复杂时,会有问题,(rowspan>1 or colspan>1),解决方法:一般都是表头格式比较复杂,可先把表头写死,然后再循环写其他数据。

网页内容如下:(可直接拷贝到记事本,然后保存为html格式,用IE打开,有问题欢迎交流:joyleo@126.com)


Html代码
1.<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  
2. 
3."http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
4. 
5.<html xmlns="http://www.w3.org/1999/xhtml"> 
6. 
7.<head> 
8.    <meta http-equiv="Content-Type" content="text/html; charset=gbk"/> 
9.    <title>WEB页面导出为EXCEL文档的方法</title> 
10.</head> 
11.<body> 
12.<table id="tableExcel" width="100%" border="1" cellspacing="0" cellpadding="0"> 
13.    <tr> 
14.        <td colspan="5" align="center">WEB页面导出为EXCEL文档的方法</td> 
15.    </tr> 
16.    <tr> 
17.        <td>列标题1</td> 
18.        <td>列标题2</td> 
19.        <td>列标题3</td> 
20.        <td>列标题4</td> 
21.        <td>列标题5</td> 
22.    </tr> 
23.    <tr> 
24.        <td>aaa</td> 
25.        <td>bbb</td> 
26.        <td>ccc</td> 
27.        <td>ddd</td> 
28.        <td>eee</td> 
29.    </tr> 
30.    <tr> 
31.        <td>AAA</td> 
32.        <td>BBB</td> 
33.        <td>CCC</td> 
34.        <td>DDD</td> 
35.        <td>EEE</td> 
36.    </tr> 
37.    <tr> 
38.        <td>FFF</td> 
39.        <td>GGG</td> 
40.        <td>HHH</td> 
41.        <td>III</td> 
42.        <td>JJJ</td> 
43.    </tr> 
44.</table> 
45.<input type="button" onclick="javascript:method1('tableExcel');" value="第一种方法导入到EXCEL"> 
46.<input type="button" onclick="javascript:method2('tableExcel');" value="第二种方法导入到EXCEL"> 
47.<input type="button" onclick="javascript:getXlsFromTbl('tableExcel',null);" value="第三种方法导入到EXCEL"> 
48. 
49.<SCRIPT LANGUAGE="javascript"> 
50.function method1(tableid) {//整个表格拷贝到EXCEL中  
51.    var curTbl = document.getElementById(tableid);  
52.    var oXL = new ActiveXObject("Excel.Application");  
53.    //创建AX对象excel  
54.    var oWB = oXL.Workbooks.Add();  
55.    //获取workbook对象  
56.    var oSheet = oWB.ActiveSheet;  
57.    //激活当前sheet  
58.    var sel = document.body.createTextRange();  
59.    sel.moveToElementText(curTbl);  
60.    //把表格中的内容移到TextRange中  
61.    sel.select();  
62.    //全选TextRange中内容  
63.    sel.execCommand("Copy");  
64.    //复制TextRange中内容   
65.    oSheet.Paste();  
66.    //粘贴到活动的EXCEL中        
67.    oXL.Visible = true;  
68.    //设置excel可见属性  
69.}  
70. 
71.function method2(tableid) //读取表格中每个单元到EXCEL中  
72.{  
73.    var curTbl = document.getElementById(tableid);  
74.    var oXL = new ActiveXObject("Excel.Application");  
75.    //创建AX对象excel  
76.    var oWB = oXL.Workbooks.Add();  
77.    //获取workbook对象  
78.    var oSheet = oWB.ActiveSheet;  
79.    //激活当前sheet  
80.    var Lenr = curTbl.rows.length;  
81.    //取得表格行数  
82.    for (i = 0; i < Lenr; i++)  
83.    {  
84.        var Lenc = curTbl.rows(i).cells.length;  
85.        //取得每行的列数  
86.        for (j = 0; j < Lenc; j++)  
87.        {  
88.            oSheet.Cells(i + 1, j + 1).value = curTbl.rows(i).cells(j).innerText;  
89.            //赋值  
90.        }  
91.    }  
92.    oXL.Visible = true;  
93.    //设置excel可见属性  
94.}  
95. 
96.function getXlsFromTbl(inTblId, inWindow) {  
97.    try {  
98.        var allStr = "";  
99.        var curStr = "";  
100.        //alert("getXlsFromTbl");  
101.        if (inTblId != null && inTblId != "" && inTblId != "null") {  
102.            curStr = getTblData(inTblId, inWindow);  
103.        }  
104. 
105.        if (curStr != null) {  
106.            allStr += curStr;  
107.        }  
108.        else {  
109.            alert("你要导出的表不存在!");  
110.            return;  
111.        }  
112. 
113.        var fileName = getExcelFileName();  
114.        doFileExport(fileName, allStr);  
115.    }  
116.    catch(e) {  
117.        alert("导出发生异常:" + e.name + "->" + e.description + "!");  
118.    }  
119.}  
120. 
121.function getTblData(inTbl, inWindow) {  
122.    var rows = 0;  
123.    //alert("getTblData is " + inWindow);  
124.    var tblDocument = document;  
125.    if (!!inWindow && inWindow != "") {  
126.        if (!document.all(inWindow)) {  
127.            return null;  
128.        }  
129.        else {  
130.            tblDocument = eval(inWindow).document;  
131.        }  
132.    }  
133. 
134.    var curTbl = tblDocument.getElementById(inTbl);  
135.    var outStr = "";  
136.    if (curTbl != null) {  
137.        for (var j = 0; j < curTbl.rows.length; j++) {  
138.            //alert("j is " + j);  
139.            for (var i = 0; i < curTbl.rows[j].cells.length; i++) {  
140.                //alert("i is " + i);  
141.                if (i == 0 && rows > 0) {  
142.                    outStr += " \t";  
143.                    rows -= 1;  
144.                }  
145.                outStr += curTbl.rows[j].cells[i].innerText + "\t";  
146.                if (curTbl.rows[j].cells[i].colSpan > 1) {  
147.                    for (var k = 0; k < curTbl.rows[j].cells[i].colSpan - 1; k++) {  
148.                        outStr += " \t";  
149.                    }  
150.                }  
151.                if (i == 0) {  
152.                    if (rows == 0 && curTbl.rows[j].cells[i].rowSpan > 1) {  
153.                        rows = curTbl.rows[j].cells[i].rowSpan - 1;  
154.                    }  
155.                }  
156.            }  
157.            outStr += "\r\n";  
158.        }  
159.    }  
160.    else {  
161.        outStr = null;  
162.        alert(inTbl + "不存在!");  
163.    }  
164.    return outStr;  
165.}  
166. 
167.function getExcelFileName() {  
168.    var d = new Date();  
169.    var curYear = d.getYear();  
170.    var curMonth = "" + (d.getMonth() + 1);  
171.    var curDate = "" + d.getDate();  
172.    var curHour = "" + d.getHours();  
173.    var curMinute = "" + d.getMinutes();  
174.    var curSecond = "" + d.getSeconds();  
175. 
176.    if (curMonth.length == 1) {  
177.        curMonth = "0" + curMonth;  
178.    }  
179.    if (curDate.length == 1) {  
180.        curDate = "0" + curDate;  
181.    }  
182.    if (curHour.length == 1) {  
183.        curHour = "0" + curHour;  
184.    }  
185.    if (curMinute.length == 1) {  
186.        curMinute = "0" + curMinute;  
187.    }  
188.    if (curSecond.length == 1) {  
189.        curSecond = "0" + curSecond;  
190.    }  
191.   
192.    var fileName = "leo_zhang" + "_" + curYear + curMonth + curDate + "_" + curHour + curMinute + curSecond + ".csv";  
193.    //alert(fileName);  
194.    return fileName;  
195.}  
196.   
197.function doFileExport(inName, inStr) {  
198.    var xlsWin = null;  
199.    if (!!document.all("glbHideFrm")) {  
200.        xlsWin = glbHideFrm;  
201.    }  
202.    else {  
203.        var width = 6;  
204.        var height = 4;  
205.        var openPara = "left=" + (window.screen.width / 2 - width / 2)  
206.                + ",top=" + (window.screen.height / 2 - height / 2)  
207.                + ",scrollbars=no,width=" + width + ",height=" + height;  
208.        xlsWin = window.open("", "_blank", openPara);  
209.    }  
210. 
211.    xlsWin.document.write(inStr);  
212.    xlsWin.document.close();  
213.    xlsWin.document.execCommand('Saveas', true, inName);  
214.    xlsWin.close();  
215.}  
216. 
217.</SCRIPT> 
218.</body> 
219.</html> 


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/free_xiang/archive/2010/12/01/6047101.aspx
分享到:
评论

相关推荐

    html页面表格导出excel(原生js浏览器全兼容)

    通过以上步骤,我们就可以实现在没有后端接口的情况下,使用原生JavaScript将HTML表格数据导出为Excel文件。提供的`js浏览器导出Excel`资源应该包含了一个示例,你可以参考这个示例代码来理解并应用到自己的项目中。...

    layui数据表格导出Excel插件

    layui数据表格导出Excel插件是一款为layui框架设计的实用工具,它允许用户方便地将layui数据表格中的数据导出到Excel文件中。layui是一款轻量级的前端UI框架,以其简洁、优雅的代码风格和丰富的组件库深受开发者喜爱...

    js 实现 用JavaScript导出图像到Excel

    js 实现 用JavaScript导出图像到Excel! 值得下载看看!资源免费,大家分享!!

    简单的导出excel表格列子

    总结来说,这个“简单的导出excel表格列子”提供了一种实用且高效的方法,通过纯JavaScript在Web页面上实现Excel导出功能,无需依赖任何插件,代码简洁易懂,对开发者来说具有很高的学习价值。通过阅读和实践压缩包...

    html表格导出为excel

    在导出表格为Excel的场景中,jQuery可以高效地选择表格元素,进而进行必要的处理。 要使用jQuery导出HTML表格为Excel,我们需要引入jQuery库和一个专门处理这个任务的插件。在这种情况下,"jquery-table2excel"是一...

    javascript将表格导出到Excel

    在JavaScript中将表格数据导出到Excel是一种常见的需求,尤其在Web应用中,用户往往希望可以方便地将数据显示在Excel表格中以便进一步处理或存储。本文将深入探讨三种不同的JavaScript方法来实现这一功能,并着重...

    JSP页面导出EXCEL简单方法

    要将JSP页面的HTML表格导出为Excel,我们通常会利用HTTP响应头来设置内容类型为`application/vnd.ms-excel`,这样浏览器就会将响应的数据解析为Excel文件。以下是简单的步骤: 1. **创建HTML表格**:在JSP页面(如...

    javaScript导出word和excel例子

    在JavaScript中,我们可以利用一些库或者API来实现HTML内容导出为Word或Excel文档的功能。这对于数据导出、报告生成或者网页内容下载等场景非常有用。以下是对标题和描述中涉及知识点的详细说明: 1. **JavaScript...

    js导出Excel 、Word [超实用][自动保存样式]

    在IT行业中,JavaScript是一种广泛使用的...对于压缩包中的"js导出Excel、word.html"文件,很可能是包含示例代码的网页,你可以通过查看和运行这段代码,更好地理解和学习JavaScript导出表格内容到Excel和Word的方法。

    用jquery-table2excel,进行导出excel表格 带图片 jquery.table2excel.js下载

    在现代Web应用中,数据的导入导出功能是不可或缺的一部分,特别是导出表格到Excel,以便用户可以方便地处理和存储数据。`jquery-table2excel`是一个jQuery插件,专门用于实现这一功能,允许用户从网页上的HTML表格...

    JS导出页面数据到excel

    在网页开发中,有时我们需要提供一个功能,让用户能够方便地将页面上的数据导出到Excel文件,以便于进一步处理或存储。"JS导出页面数据到excel"这个工具类程序正是为了解决这个问题。它实现了在不依赖后端服务器代码...

    easyui+数据导出为Excel

    在IT行业中,前端数据处理和展示是至关重要的,特别是在企业级应用中,用户往往需要将大量数据导出为便于分析的格式,如Excel。本文将详细介绍如何在基于EasyUI的前端框架下实现数据导出为Excel的功能。 EasyUI是一...

    JavaScript 实现 Excel数据导出 支持多个Sheet页导出

    在前端开发中,有时我们需要为用户提供将数据导出到Excel的功能,这在处理大量表格数据时尤为实用。本文将深入探讨如何使用纯JavaScript实现JSON格式数据到Excel文件的导出,同时支持多个Sheet页的导出。这个功能...

    使用js导出带样式的excel表格

    总的来说,使用JavaScript导出带样式的Excel表格涉及了对数据的组织、样式定义以及文件生成等多个环节。通过SheetJS库,我们可以轻松地实现这一功能,提供给用户高质量的导出体验。在实际项目中,还可以根据需求进行...

    jquery表格导出插件表格为Excel和pdf文档的详细实例源码.rar

    在IT行业中,数据的导入与导出是常见的需求,特别是在Web应用中,用户可能需要将网页上的表格数据保存为本地的文件格式,如Excel或PDF,以便进一步处理或分享。`jQuery`是一款广泛使用的JavaScript库,它简化了DOM...

    vue导出excel表格Blob,Export2Excel

    在Vue.js应用中,我们经常需要处理数据导出到Excel表格的需求,这在数据分析、报表展示等场景下尤其常见。`Blob`对象和`Export2Excel`方法是实现这一功能的关键技术。`Blob`(Binary Large Object)是用于存储二进制...

    table表格导出为excel

    通过以上介绍,我们可以看出,将table表格导出为excel是网页开发中的一个重要功能,它涉及前端和后端技术,以及对数据处理和用户体验的理解。在实际项目中,开发者需要根据具体需求和环境选择合适的工具和方法来实现...

    前端页面导出table中的内容到excel

    通过以上技术,开发者可以在前端页面上实现将table表格数据导出为Excel的功能,提供用户友好的数据交互体验。在实际项目中,结合具体的业务需求和现有技术栈,选择合适的方法和库,可以高效地完成这一任务。

    excel.js(导出excel表格)

    excel.js(导出excel表格)

Global site tag (gtag.js) - Google Analytics