Excel转html

项目开发流程中,需求涉及到了各种文档转换为Html或者网页易显示格式,现在将实现方式整理如下:

一、运用 Jacob转换Word,Excel为HTML

“JACOB一个Java-COM中间件.通过这个组件你可以在Java应用程序中调用COM组件和Win32 libraries。”

首先下载Jacob包,JDK1.5以上须要运用 Jacob1.9版本(JDK1.6尚未测试),与先前的Jacob1.7差别不大

1、将压缩包解压后,Jacob.jar添加到Libraries中;

2、将Jacob.dll放至“WINDOWSSYSTEM32”下面。

须要留心的是:

【运用 IDE启动Web服务器时,系统读取不到Jacob.dll,例如用MyEclipse启动Tomcat,就须要将dll文件copy到MyEclipse安装目录的“jrebin”下面。

一般系统没有加载到Jacob.dll文件时,报错信息为:“java.lang.UnsatisfiedLinkError: no jacob in java.library.path”】

新建类:

Java代码

public class JacobUtil
{
public static final int WORD_HTML = 8;

public static final int WORD_TXT = 7;

public static final int EXCEL_HTML = 44;

/**
* WORD转HTML
* @param docfile WORD文件全路径
* @param htmlfile 转换后HTML存放路径
*/
public static void wordToHtml(String docfile, String htmlfile)
{
ActiveXComponent app = new ActiveXComponent("Word.Application"); // 启动word
try
{
app.setProperty("Visible", new Variant(false));
Dispatch docs = app.getProperty("Documents").toDispatch();
Dispatch doc = Dispatch.invoke(
docs,
"Open",
Dispatch.Method,
new Object[] { docfile, new Variant(false),
new Variant(true) }, new int[1]).toDispatch();
Dispatch.invoke(doc, "SaveAs", Dispatch.Method, new Object[] {
htmlfile, new Variant(WORD_HTML) }, new int[1]);
Variant f = new Variant(false);
Dispatch.call(doc, "Close", f);
}
catch (Exception e)
{
e.printStackTrace();
}
finally
{
app.invoke("Quit", new Variant[] {});
}
}

/**
* EXCEL转HTML
* @param xlsfile EXCEL文件全路径
* @param htmlfile 转换后HTML存放路径
*/
public static void excelToHtml(String xlsfile, String htmlfile)
{
ActiveXComponent app = new ActiveXComponent("Excel.Application"); // 启动word
try
{
app.setProperty("Visible", new Variant(false));
Dispatch excels = app.getProperty("Workbooks").toDispatch();
Dispatch excel = Dispatch.invoke(
excels,
"Open",
Dispatch.Method,
new Object[] { xlsfile, new Variant(false),
new Variant(true) }, new int[1]).toDispatch();
Dispatch.invoke(excel, "SaveAs", Dispatch.Method, new Object[] {
htmlfile, new Variant(EXCEL_HTML) }, new int[1]);
Variant f = new Variant(false);
Dispatch.call(excel, "Close", f);
}
catch (Exception e)
{
e.printStackTrace();
}
finally
{
app.invoke("Quit", new Variant[] {});
}
}

}

源文档 <http://www.vipcn.com/chengxukaifa/Java/316340.html>

java.lang.UnsatisfiedLinkError: no jacob in java.library.path

源文档 <http://hi.baidu.com/mingfang0219/blog/item/bcfc8972a14fe7108701b0df.html>

下载jacob.rar,解压出jacob.dll和jacob.jar

然后:

1) 把jacob.dll在 C:/Program Files/Java/jdk1.5.0_08/bin、C:/Program Files/Java/jdk1.5.0_08/jre/bin、C:/WINDOWS/system32 目录下各.放一份

2) 把jacob.jar放入 项目的lib包下,并且在“java构建路径”中也要加载此jar包。.

3) 运行项目即可编译通过.

注:

1)这样配置后不需要再配置环境变量(如:path,classpath)了.

### 如何将Excel文件导出或保存为HTML格式 要将Excel文件换为HTML格式,可以借助一些现有的JavaScript库来完成此操作。以下是几种方法及其对应的工具: #### 方法一:使用 XLSX.js Excel 文件到 HTML 表格 XLSX.js 是一款强大的 JavaScript 库,能够解析和生成多种类型的电子表格文件[^2]。通过该库,我们可以加载 Excel 数据并将其渲染为 HTML。 以下是一个简单的代码示例,展示如何使用 XLSX.js 将 Excel 文件中的数据提取出来,并以 HTML 的形式显示在页面上: ```javascript function handleFile(e) { const file = e.target.files[0]; const reader = new FileReader(); reader.onload = function (e) { const data = new Uint8Array(e.target.result); const workbook = XLSX.read(data, { type: 'array' }); // 获取第一个工作表名称 const firstSheetName = workbook.SheetNames[0]; const worksheet = workbook.Sheets[firstSheetName]; // 将工作表换为 HTML 字符串 document.body.innerHTML += XLSX.utils.sheet_to_html(worksheet); }; reader.readAsArrayBuffer(file); } document.getElementById('upload').addEventListener('change', handleFile, false); ``` 上述代码片段展示了如何监听文件上传事件,读取 Excel 文件的内容,并将其作为 HTML 插入到网页中。 --- #### 方法二:使用 SheetJS/js-xlsx 实现更复杂的场景 如果需要更多自定义选项或者支持更多的 Excel 版本,则可以选择 `js-xlsx` 这款工具[^3]。它可以处理各种复杂的数据结构以及样式信息。 下面是一段扩展的例子,演示了如何从 Excel 中获取特定列的数据并动态构建 HTML 表格: ```javascript function convertToHtml() { const input = document.getElementById('fileInput'); const file = input.files[0]; const reader = new FileReader(); reader.onload = function(event) { const data = new Uint8Array(event.target.result); const workbook = XLSX.read(data, {type: 'array'}); const sheetName = workbook.SheetNames[0]; // 假设只有一张表单 const worksheet = workbook.Sheets[sheetName]; const htmlStr = XLSX.utils.sheet_to_html(worksheet); // 动态创建一个 div 并插入 HTML 结果 const containerDiv = document.createElement('div'); containerDiv.innerHTML = htmlStr; document.body.appendChild(containerDiv); }; reader.readAsArrayBuffer(file); } ``` 这段脚本允许用户选择本地的一个 `.xlsx` 或其他兼容格式的文档,随后会自动把其内容呈现为标准 HTML `<table>` 元素。 --- #### 方法三:Table to Excel 2 反向操作的可能性探讨 虽然 Table to Excel 2 主要是用于将 HTML 导出至 Excel 文件的功能[^1],但它背后依赖于 `exceljs` 和类似的框架,理论上也可以反向操作——即先用这些底层组件载入 Excel 文档再输出成 HTML 形式。不过官方并未直接提供这样的接口,因此可能需要额外编写适配逻辑才能达成目标。 --- ### 总结 综上所述,推荐优先考虑 **XLSX.js** 来满足大多数情况下关于 ExcelHTML 的需求;而对于更加灵活的需求则可探索基于 `js-xlsx` 提供的支持方案。至于像 *Table To Excel* 类型插件更适合解决相反方向的任务(即将现有 DOM 渲染成果打包存盘),并不完全适合当前主题讨论范围内的用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值