国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Javascript實現(xiàn)把網(wǎng)頁中table的內容導入到excel中的幾種方法__摘錄 - zgqynx - JavaEye技術網(wǎng)站
Javascript實現(xiàn)把網(wǎng)頁中table的內容導入到excel中的幾種方法

一、 直接拷貝整個表格到EXCEL中

二、 通過遍歷表格,給EXCEL中相應的單元格賦值。

三、 把表格中的內容提取出來,利用IE的另存為.csv的格式。

各方法的好處:

1. 直接拷貝表格,能夠保留表格中的原有的格式,比如,列,行的合并,對齊方式,底色等等,

2. 通過遍歷表格,比較靈活,可以遍歷表格某些需要部分的內容。

3. 利用IE的另存為,不用創(chuàng)建ActiveXObject對象,可以處理表格合并方面的問題。

各方法的缺點:

1. 可能彈出腳本錯誤:Automation不能創(chuàng)建對象。

解決方法:啟用IE安全設置中的:對沒有標記為安全的ActiveX控件進行初始化和腳本運行。

由于整個表格復制到EXCEL中,給表格加個標題,并加入到EXCEL中可能會遇到麻煩。

解決方法:首先在表格中加入第一行

<tr><td colspan="x" align="center">&</td></tr>

X,表示整個表格的列數(shù),復制完整個表格后,加如下代碼,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不能創(chuàng)建對象(解決方法如上)。

表格內容寫入到EXCEL中無表格線(未解決)

且有單元格合并時會有問題,解決方法:合并單元格后再寫數(shù)據(jù)。

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



3. 表格內容寫入到EXCEL中無表格線(未解決)

表格格式復雜時,會有問題,(rowspan>1 or colspan>1),解決方法:一般都是表頭格式比較復雜,可先把表頭寫死,然后再循環(huán)寫其他數(shù)據(jù)。



網(wǎng)頁內容如下:(可直接拷貝到記事本,然后保存為html格式,用IE打開,有問題歡迎交流:joyleo@126.com)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

<title>WEB頁面導出為EXCEL文檔的方法</title>

</head>



<body>

<table id="tableExcel" width="100%" border="1" cellspacing="0" cellpadding="0">

<tr>

<td colspan="5" align="center">WEB頁面導出為EXCEL文檔的方法</td>

</tr>

<tr>

<td>列標題1</td>

<td>列標題2</td>

<td>列標題3</td>

<td>列標題4</td>

<td>列標題5</td>

</tr>

<tr>

<td>aaa</td>

<td>bbb</td>

<td>ccc</td>

<td>ddd</td>

<td>eee</td>

</tr>

<tr>

<td>AAA</td>

<td>BBB</td>

<td>CCC</td>

<td>DDD</td>

<td>EEE</td>

</tr>

<tr>

<td>FFF</td>

<td>GGG</td>

<td>HHH</td>

<td>III</td>

<td>JJJ</td>

</tr>



</table>





<input type="button" onclick="javascript:method1(‘tableExcel‘);" value="第一種方法導入到EXCEL">

<input type="button" onclick="javascript:method2(‘tableExcel‘);" value="第二種方法導入到EXCEL">

<input type="button" onclick="javascript:getXlsFromTbl(‘tableExcel‘,null);" value="第三種方法導入到EXCEL">

<SCRIPT LANGUAGE="javascript">

function method1(tableid) {//整個表格拷貝到EXCEL中

var curTbl = document.getElementById(tableid);

var oXL = new ActiveXObject("Excel.Application");

//創(chuàng)建AX對象excel

var oWB = oXL.Workbooks.Add();

//獲取workbook對象

var oSheet = oWB.ActiveSheet;

//激活當前sheet

var sel = document.body.createTextRange();

sel.moveToElementText(curTbl);

//把表格中的內容移到TextRange中

sel.select();

//全選TextRange中內容

sel.execCommand("Copy");

//復制TextRange中內容

oSheet.Paste();

//粘貼到活動的EXCEL中

oXL.Visible = true;

//設置excel可見屬性

}

function method2(tableid) //讀取表格中每個單元到EXCEL中

{

var curTbl = document.getElementById(tableid);

var oXL = new ActiveXObject("Excel.Application");

//創(chuàng)建AX對象excel

var oWB = oXL.Workbooks.Add();

//獲取workbook對象

var oSheet = oWB.ActiveSheet;

//激活當前sheet

var Lenr = curTbl.rows.length;

//取得表格行數(shù)

for (i = 0; i < Lenr; i++)

{

var Lenc = curTbl.rows(i).cells.length;

//取得每行的列數(shù)

for (j = 0; j < Lenc; j++)

{

oSheet.Cells(i + 1, j + 1).value = curTbl.rows(i).cells(j).innerText;

//賦值

}

}

oXL.Visible = true;

//設置excel可見屬性

}

function getXlsFromTbl(inTblId, inWindow) {

try {

var allStr = "";

var curStr = "";



//alert("getXlsFromTbl");

if (inTblId != null && inTblId != "" && inTblId != "null") {

curStr = getTblData(inTblId, inWindow);

}



if (curStr != null) {

allStr += curStr;

}

else {

alert("你要導出的表不存在!");

return;

}



var fileName = getExcelFileName();

doFileExport(fileName, allStr);



}

catch(e) {

alert("導出發(fā)生異常:" + e.name + "->" + e.description + "!");

}

}

function getTblData(inTbl, inWindow) {

var rows = 0;



//alert("getTblData is " + inWindow);

var tblDocument = document;



if (!!inWindow && inWindow != "") {

if (!document.all(inWindow)) {

return null;

}

else {

tblDocument = eval(inWindow).document;

}

}



var curTbl = tblDocument.getElementById(inTbl);



var outStr = "";



if (curTbl != null) {

for (var j = 0; j < curTbl.rows.length; j++) {

//alert("j is " + j);

for (var i = 0; i < curTbl.rows[j].cells.length; i++) {

//alert("i is " + i);

if (i == 0 && rows > 0) {

outStr += " \t";

rows -= 1;

}

outStr += curTbl.rows[j].cells[i].innerText + "\t";

if (curTbl.rows[j].cells[i].colSpan > 1) {

for (var k = 0; k < curTbl.rows[j].cells[i].colSpan - 1; k++) {

outStr += " \t";

}

}

if (i == 0) {

if (rows == 0 && curTbl.rows[j].cells[i].rowSpan > 1) {

rows = curTbl.rows[j].cells[i].rowSpan - 1;

}

}

}

outStr += "\r\n";

}

}

else {

outStr = null;

alert(inTbl + "不存在!");

}

return outStr;

}

function getExcelFileName() {

var d = new Date();



var curYear = d.getYear();

var curMonth = "" + (d.getMonth() + 1);

var curDate = "" + d.getDate();

var curHour = "" + d.getHours();

var curMinute = "" + d.getMinutes();

var curSecond = "" + d.getSeconds();



if (curMonth.length == 1) {

curMonth = "0" + curMonth;

}

if (curDate.length == 1) {

curDate = "0" + curDate;

}

if (curHour.length == 1) {

curHour = "0" + curHour;

}

if (curMinute.length == 1) {

curMinute = "0" + curMinute;

}

if (curSecond.length == 1) {

curSecond = "0" + curSecond;

}



var fileName = "leo_zhang" + "_" + curYear + curMonth + curDate + "_"

+ curHour + curMinute + curSecond + ".csv";

//alert(fileName);

return fileName;

}



function doFileExport(inName, inStr) {

var xlsWin = null;



if (!!document.all("glbHideFrm")) {

xlsWin = glbHideFrm;

}

else {

var width = 6;

var height = 4;

var openPara = "left=" + (window.screen.width / 2 - width / 2)

+ ",top=" + (window.screen.height / 2 - height / 2)

+ ",scrollbars=no,width=" + width + ",height=" + height;

xlsWin = window.open("", "_blank", openPara);

}



xlsWin.document.write(inStr);

xlsWin.document.close();

xlsWin.document.execCommand(‘Saveas‘, true, inName);

xlsWin.close();

}

</SCRIPT>

</body>

</html>

原帖http://www.cublog.cn/u/23292/showart_162129.html
本站僅提供存儲服務,所有內容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權內容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
jsp頁面中table轉化到excel輸出
html頁面表格導出到excel總結 | 守望軒
用js來實現(xiàn)導出數(shù)據(jù)到Excel
Python&JS宏 實現(xiàn)保留樣式合并表格后拆分
js導入導出excel
將WinCC的歷史數(shù)據(jù)寫入Excel文件
更多類似文章 >>
生活服務
分享 收藏 導長圖 關注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服