用js将base64图片导入到xlsx文件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Export Excel with Images</title> <script src="https://cdnjs.cloudflare.com/ajax/libs/exceljs/4.2.0/exceljs.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2.0.5/FileSaver.min.js"></script> </head> <body> <button onclick="exportExcel()">Export to Excel</button> <script> async function exportExcel() { const workbook = new ExcelJS.Workbook(); const worksheet = workbook.addWorksheet('Sheet1'); // Add headers worksheet.columns = [ { header: 'ID', key: 'id', width: 10 }, { header: 'Name', key: 'name', width: 32 }, { header: 'Picture', key: 'picture', width: 32 } ]; // Example data const data = [ { id: 1, name: 'Alice', image: "..." }, // Replace with your base64 image data { id: 2, name: 'Bob', image: "..." }, { id: 3, name: 'Charlie', image: "..." } ]; // Add data to worksheet data.forEach((item, index) => { const rowIndex = index + 2; // Start from the second row worksheet.addRow({ id: item.id, name: item.name }); // Add the image to the worksheet if (item.image.startsWith('data:image/')) { const imageId = workbook.addImage({ base64: item.image, extension: 'png' }); worksheet.addImage(imageId, { tl: { col: 2, row: rowIndex - 1 }, ext: { width: 100, height: 100 } }); } }); // Generate Excel file const buffer = await workbook.xlsx.writeBuffer(); // Save Excel file const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }); saveAs(blob, 'example_with_images.xlsx'); } </script> </body> </html>
分类:
JavaScript
标签:
JavaScript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术