这次给大家带来js-xlsx的工具类库xlsxUtils的使用详解,使用js-xlsx的工具类库xlsxUtils的的注意事项有哪些,下面就是实战案例,一起来看一下。
函数说明:
var xlsxUtils = { Binary: { fixdata(data) { //文件流转BinaryString //...... }, s2ab(s) { //字符串转字符流 //...... } }, _wb: null,//缓存导入时的Workbook _rABS: false,//设置读取方式 /** * @desc 导入根据文件 * @param {File} f 文件 * @param {Function} c 回调 * @return {Object} 回调值 */ import(f, c) { //...... }, /** * @desc 根据表Sheet名获取数据 * @param {String} name * @return {Object} */ getSheetByName(name) {// //...... }, /** * @desc 根据表Sheet索引获取数据 * @param {Number} index * @return {Object} */ getSheetByIndex(index = 0) { //...... }, /** * @desc 导出 * @param {Array} data 数据{title1:dataList,title2:dataList....} * @param {String} type * @return {Blob} */ export(data, type) { //...... }, /** * 从数据数组或对象中根据key生成相同key值的对象 * @param {Object|Array} data * @return {Object} */ readDataHead(data) { //...... }, /** * @desc 格式化数据为Sheet格式 * @param {Array} json 数据 */ format2Sheet(json, n) { //...... }, /** * @desc 格式化数据为Sheet格式 * @param {Array} sheetData * @param {String} title * @param {Object} wb */ format2WB(sheetData, title = "mySheet", wb) { //...... }, /** * @desc 将xlsx Workbook 转为blob * @param {Array} wb * @param {String} type 类型 */ format2Blob(wb, type) { //...... }, /** * @desc 匹配单元格对应的标识 * @param {Number} n */ getCharCol(n) { //...... }, };
示例:
导入示例(在线示例):
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <script src="http://oss.sheetjs.com/js-xlsx/xlsx.core.min.js"></script> <script src="./xlsx.utils.js"></script></head><body> <input type="file" id="demo" /> <div id="loadInfo"></div> <div> <div> <label>SheetNames</label>: <span id="SheetNames"></span> </div> <div> <label id="demoName"></label>(示例): <span id="demoData"></span> </div> </div> <script> var demo = document.getElementById("demo"); demo.onchange = function () { let f = this.files[0]; let loadInfo = document.getElementById("loadInfo"); let demoName = document.getElementById("demoName"); let demoData = document.getElementById("demoData"); loadInfo.innerHTML = "正在读取请骚等"; demoName.innerHTML = ""; demoData.innerHTML = ""; xlsxUtils.import(f, (w) => { document.getElementById("SheetNames").innerHTML = JSON.stringify(w.SheetNames); demoName.innerHTML = w.SheetNames[0]; demoData.innerHTML = JSON.stringify(xlsxUtils.getSheetByIndex(0)); loadInfo.innerHTML = "读取完成"; }); }; </script></body></html>
导出示例(在线示例)
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>demo</title> <script src="http://oss.sheetjs.com/js-xlsx/xlsx.core.min.js"></script> <script src="xlsx.utils.min.js"></script> <script src="saveAs.min.js"> </script></head><body> <script> var data = [{ 主页: "111", 名称: "6800", 数量: "6800", 昵称: "广告主网" }, { 主页: "433", 名称: "6800", 数量: "6800", 昵称: "广告主网" }, { 名称: "22", 商家: "6800", 数量: "6800", 昵称: "广告主网", }, { 名称: "43", 商家: "6800", 数量: "6800", 昵称: "广告主网", }, { 店家: "43", 价格: "6800", 数量: "6800", 昵称: "广告主网", }]; </script> <button id="down">导出</button> <script> var down = document.getElementById("down"); down.onclick = function () { data.unshift(xlsxUtils.readDataHead(data)); var blob = xlsxUtils.export({ "Sheet1": data, "Sheet2": [{ "a": "A", "b": "B" }, { "a": 1, "b": "2" }, { "a": 3, "b": 4 }, { "a": 5, "b": 6 }] }); saveAs(URL.createObjectURL(blob), "aa.xlsx"); }; </script></body></html>
自定义起始列导出示例(在线示例)
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>demo</title> <script src="http://oss.sheetjs.com/js-xlsx/xlsx.core.min.js"></script> <script src="xlsx.utils.min.js"></script> <script src="saveAs.min.js"> </script></head><body> <script> var data = [{ 主页: "111", 名称: "6800", 数量: "6800", 昵称: "广告主网" }, { 主页: "433", 名称: "6800", 数量: "6800", 昵称: "广告主网" }, { 名称: "22", 商家: "6800", 数量: "6800", 昵称: "广告主网", }, { 名称: "43", 商家: "6800", 数量: "6800", 昵称: "广告主网", }, { 店家: "43", 价格: "6800", 数量: "6800", 昵称: "广告主网", }]; </script> <button id="down">导出</button> <script> var down = document.getElementById("down"); down.onclick = function () { data.unshift(xlsxUtils.readDataHead(data)); var tmpdata = xlsxUtils.format2Sheet(data, 2); var tmpWB = xlsxUtils.format2WB(tmpdata, "Sheet1"); tmpdata = xlsxUtils.format2Sheet([{ "a": "A", "b": "B" }, { "a": 1, "b": "2" }, { "a": 3, "b": 4 }, { "a": 5, "b": 6 }], 4); tmpWB = xlsxUtils.format2WB(tmpdata, "Sheet2", tmpWB); var blob = xlsxUtils.format2Blob(tmpWB); saveAs(URL.createObjectURL(blob), "aa.xlsx"); }; </script></body></html>
多数据合并导出到单表示例(在线示例)
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>demo</title> <script src="http://oss.sheetjs.com/js-xlsx/xlsx.core.min.js"></script> <script src="xlsx.utils.min.js"></script> <script src="saveAs.min.js"> </script></head><body> <script> var data = [{ 主页: "111", 名称: "6800", 数量: "6800", 昵称: "广告主网" }, { 主页: "433", 名称: "6800", 数量: "6800", 昵称: "广告主网" }, { 名称: "22", 商家: "6800", 数量: "6800", 昵称: "广告主网", }, { 名称: "43", 商家: "6800", 数量: "6800", 昵称: "广告主网", }, { 店家: "43", 价格: "6800", 数量: "6800", 昵称: "广告主网", }]; </script> <button id="down">导出</button> <script> var down = document.getElementById("down"); down.onclick = function () { var d1 = xlsxUtils.format2Sheet([{ "a": "A", "b": "B" }, { "a": 1, "b": "2" }, { "a": 3, "b": 4 }, { "a": 5, "b": 6 }]); var h=xlsxUtils.readDataHead(data);//读取data的列头数据 data.unshift(h);//将列头追加到最data的前 var em={};//用于换行 Object.keys(h).forEach((v)=>{ em[v]=""; }); for(var i=0;i<5;i++){//换5行 data.unshift(em); } var d2 = xlsxUtils.format2Sheet(data, 3);//3代表从D列开始 d1=Object.assign(d1,d2); var tmpWB = xlsxUtils.format2WB(d1, "Sheet1"); var blob = xlsxUtils.format2Blob(tmpWB); saveAs(URL.createObjectURL(blob), "aa.xlsx"); }; </script></body></html>
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
相关阅读:
Atas ialah kandungan terperinci js-xlsx的工具类库xlsxUtils的使用详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Python dan JavaScript mempunyai kelebihan dan kekurangan mereka sendiri dari segi komuniti, perpustakaan dan sumber. 1) Komuniti Python mesra dan sesuai untuk pemula, tetapi sumber pembangunan depan tidak kaya dengan JavaScript. 2) Python berkuasa dalam bidang sains data dan perpustakaan pembelajaran mesin, sementara JavaScript lebih baik dalam perpustakaan pembangunan dan kerangka pembangunan depan. 3) Kedua -duanya mempunyai sumber pembelajaran yang kaya, tetapi Python sesuai untuk memulakan dengan dokumen rasmi, sementara JavaScript lebih baik dengan MDNWebDocs. Pilihan harus berdasarkan keperluan projek dan kepentingan peribadi.

Peralihan dari C/C ke JavaScript memerlukan menyesuaikan diri dengan menaip dinamik, pengumpulan sampah dan pengaturcaraan asynchronous. 1) C/C adalah bahasa yang ditaip secara statik yang memerlukan pengurusan memori manual, manakala JavaScript ditaip secara dinamik dan pengumpulan sampah diproses secara automatik. 2) C/C perlu dikumpulkan ke dalam kod mesin, manakala JavaScript adalah bahasa yang ditafsirkan. 3) JavaScript memperkenalkan konsep seperti penutupan, rantaian prototaip dan janji, yang meningkatkan keupayaan pengaturcaraan fleksibiliti dan asynchronous.

Enjin JavaScript yang berbeza mempunyai kesan yang berbeza apabila menguraikan dan melaksanakan kod JavaScript, kerana prinsip pelaksanaan dan strategi pengoptimuman setiap enjin berbeza. 1. Analisis leksikal: Menukar kod sumber ke dalam unit leksikal. 2. Analisis Tatabahasa: Menjana pokok sintaks abstrak. 3. Pengoptimuman dan Penyusunan: Menjana kod mesin melalui pengkompil JIT. 4. Jalankan: Jalankan kod mesin. Enjin V8 mengoptimumkan melalui kompilasi segera dan kelas tersembunyi, Spidermonkey menggunakan sistem kesimpulan jenis, menghasilkan prestasi prestasi yang berbeza pada kod yang sama.

Aplikasi JavaScript di dunia nyata termasuk pengaturcaraan sisi pelayan, pembangunan aplikasi mudah alih dan Internet of Things Control: 1. Pengaturcaraan sisi pelayan direalisasikan melalui node.js, sesuai untuk pemprosesan permintaan serentak yang tinggi. 2. Pembangunan aplikasi mudah alih dijalankan melalui reaktnatif dan menyokong penggunaan silang platform. 3. Digunakan untuk kawalan peranti IoT melalui Perpustakaan Johnny-Five, sesuai untuk interaksi perkakasan.

Saya membina aplikasi SaaS multi-penyewa berfungsi (aplikasi edTech) dengan alat teknologi harian anda dan anda boleh melakukan perkara yang sama. Pertama, apakah aplikasi SaaS multi-penyewa? Aplikasi SaaS Multi-penyewa membolehkan anda melayani beberapa pelanggan dari Sing

Artikel ini menunjukkan integrasi frontend dengan backend yang dijamin oleh permit, membina aplikasi edtech SaaS yang berfungsi menggunakan Next.Js. Frontend mengambil kebenaran pengguna untuk mengawal penglihatan UI dan memastikan permintaan API mematuhi dasar peranan

JavaScript adalah bahasa utama pembangunan web moden dan digunakan secara meluas untuk kepelbagaian dan fleksibiliti. 1) Pembangunan front-end: Membina laman web dinamik dan aplikasi satu halaman melalui operasi DOM dan kerangka moden (seperti React, Vue.js, sudut). 2) Pembangunan sisi pelayan: Node.js menggunakan model I/O yang tidak menyekat untuk mengendalikan aplikasi konkurensi tinggi dan masa nyata. 3) Pembangunan aplikasi mudah alih dan desktop: Pembangunan silang platform direalisasikan melalui reaktnatif dan elektron untuk meningkatkan kecekapan pembangunan.

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini