C#操作WPS表格

方法1、后期绑定动态调用。通过System.Type动态创建对象,避免直接依赖 COM 引用:

using System;

using System.Runtime.InteropServices;

class Program

{

static void Main()

{

object wpsApp = Activator.CreateInstance(Type.GetTypeFromProgID("Ket.Application"));

dynamic excel = wpsApp;

excel.Visible = true;

dynamic workbook = excel.Workbooks.Add();

dynamic sheet = workbook.Sheets1;

sheet.Cells1, 1.Value = "Hello WPS!";

workbook.SaveAs("C:\\Test.xlsx");

workbook.Close();

excel.Quit();

Marshal.ReleaseComObject(excel);

}

}

方法2:在C#中通过COM操作WPS Excel文件时,需引用WPS安装目录下的etapi.dll文件,并使用对应的ProgID创建实例。

3、截图例子:

using System;

using System.Drawing;

using System.Drawing.Imaging;

using System.Runtime.InteropServices;

using System.Windows.Forms;

class Program

{

STAThread // 剪贴板操作需要STA线程

static void Main()

{

try

{

// 创建Excel/WPS实例

object wpsApp = Activator.CreateInstance(Type.GetTypeFromProgID("Excel.Application") ??

Type.GetTypeFromProgID("Ket.Application"));

dynamic excel = wpsApp;

excel.Visible = true; // 必须可见才能截图

// 打开指定的Excel文件

string filePath = @"c:\1.xls";

dynamic workbook = excel.Workbooks.Open(filePath);

dynamic sheet = workbook.Sheets1;

// 选择要截图的区域(A1到P25)

dynamic range = sheet.Range("A1:P25");

range.Select();

// 复制为图片到剪贴板

range.CopyPicture(XlPictureAppearance.xlScreen, XlCopyPictureFormat.xlBitmap);

// 从剪贴板获取图片

if (Clipboard.ContainsImage())

{

Image img = Clipboard.GetImage();

// 保存图片到C盘

string savePath = @"C:\ExcelScreenshot.png";

img.Save(savePath, ImageFormat.Png);

Console.WriteLine($"截图已保存至:{savePath}");

}

// 清理资源

workbook.Close(false);

excel.Quit();

Marshal.ReleaseComObject(range);

Marshal.ReleaseComObject(sheet);

Marshal.ReleaseComObject(workbook);

Marshal.ReleaseComObject(excel);

}

catch (Exception ex)

{

Console.WriteLine($"错误发生:{ex.Message}");

}

finally

{

// 强制垃圾回收

GC.Collect();

GC.WaitForPendingFinalizers();

}

}

}

// 需要添加的COM引用

public enum XlPictureAppearance

{

xlScreen = 1,

xlPrinter = 2

}

public enum XlCopyPictureFormat

{

xlBitmap = 2,

xlPicture = -4147

}

4、截图例子:

using System;

using System.Drawing;

using System.Drawing.Imaging;

using System.Runtime.InteropServices;

using System.Windows.Forms;

class Program

{

STAThread

static void Main()

{

try

{

// 创建WPS实例

object wpsApp = Activator.CreateInstance(Type.GetTypeFromProgID("Ket.Application"));

dynamic excel = wpsApp;

excel.Visible = true; // 必须可见才能截图

// 打开现有工作簿

dynamic workbook = excel.Workbooks.Open(@"C:\1.xls");

dynamic sheet = workbook.Sheets1; // 获取第一个工作表

// 选择要截图的区域(A1到P25)

dynamic range = sheet.Range("A1:P25");

range.Select();

// 复制为图片到剪贴板

range.CopyPicture(XlPictureAppearance.xlScreen, XlCopyPictureFormat.xlBitmap);

// 从剪贴板获取图片

if (Clipboard.ContainsImage())

{

Image img = Clipboard.GetImage();

// 保存图片到C盘

string savePath = @"C:\ExcelScreenshot2.png";

img.Save(savePath, ImageFormat.Png);

Console.WriteLine($"截图已保存至:{savePath}");

}

// 清理资源

workbook.Close(false);

excel.Quit();

Marshal.ReleaseComObject(range);

Marshal.ReleaseComObject(sheet);

Marshal.ReleaseComObject(workbook);

Marshal.ReleaseComObject(excel);

}

catch (Exception ex)

{

Console.WriteLine($"错误发生:{ex.Message}");

}

finally

{

// 强制垃圾回收

GC.Collect();

GC.WaitForPendingFinalizers();

}

}

}

// 需要添加的COM引用

public enum XlPictureAppearance

{

xlScreen = 1,

xlPrinter = 2

}

public enum XlCopyPictureFormat

{

xlBitmap = 2,

xlPicture = -4147

}

5、

using System;

class Program

{

static void Main()

{

try

{

Type excelType = Type.GetTypeFromProgID("KWPS.Application"); // WPS表格的ProgID

if (excelType != null)

{

dynamic excelApp = Activator.CreateInstance(excelType);

excelApp.Visible = true; // 让WPS表格可见,以便观察

Console.WriteLine("WPS Excel COM 对象创建成功!按Enter退出...");

Console.ReadLine();

excelApp.Quit(); // 关闭WPS

}

else

{

Console.WriteLine("未找到 WPS Excel COM 组件注册。");

}

}

catch (Exception ex)

{

Console.WriteLine($"出错: {ex.Message}");

}

}

}

相关推荐
better_liang13 分钟前
每日Java面试场景题知识点之-如何设计分布式锁
java·redis·zookeeper·面试·分布式锁
战族狼魂14 分钟前
集 “自动飞行、智能识别、实时预警、勤务联动” 于一体的高速公路应急车道无人机检测系统方案
java·人工智能·大模型·无人机
一只鹿鹿鹿22 分钟前
信息化项目管理规范(参考Word文件)
java·大数据·运维·开发语言·数据库
Java小白笔记23 分钟前
Linux 手动部署 Oracle JDK 17 完全指南
java·linux·oracle
夕除23 分钟前
实战--2
java·spring boot·spring
Chase_______29 分钟前
【Java杂项】final 关键字详解:变量、方法、类限制与引用可变性
java·开发语言·python
凤山老林1 小时前
DDD(领域驱动设计)在复杂业务系统中的落地指南
java·开发语言·数据库·ddd·领域驱动
JEECG低代码平台1 小时前
JimuChatBI — 首款免费开源的 Java 智能问数ChatBI平台,零成本接入,AI对话式智能分析
java·人工智能·开源·aigc·人工智能低代码
csdn_aspnet2 小时前
Modbus TCP C# 客户端程序
服务器·网络·tcp/ip·c#