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.Sheets[1];

sheet.Cells[1, 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.Sheets\[1\]; // 选择要截图的区域(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.Sheets[1]; // 获取第一个工作表

// 选择要截图的区域(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}");

}

}

}

相关推荐
come112344 小时前
深入Spring Boot的核心——配置管理(指南四)
java·spring boot·后端
武昌库里写JAVA5 小时前
Java 设计模式在 Spring 框架中的实践:工厂模式与单例模式
java·vue.js·spring boot·sql·学习
该用户已不存在5 小时前
.NET语言大舞台,有才你就来
c#·.net
麦兜*5 小时前
Redis高可用架构设计:主从复制、哨兵、Cluster集群模式深度对比
java·数据库·spring boot·redis·spring·spring cloud·缓存
王嘉俊9255 小时前
Redis 入门:高效缓存与数据存储的利器
java·数据库·redis·后端·spring·缓存·springboot
王维5 小时前
【shardingsphere-jdbc】分表实践
java·数据库
道可到6 小时前
淘宝面试原题 Java 面试通关笔记 02|从编译到运行——Java 背后的计算模型(面试可复述版)
java·后端·面试
DKPT6 小时前
JVM如何管理直接内存?
java·笔记·学习
SimonKing6 小时前
GitHub 标星 370k!免费编程资源大合集,从此自学不花一分钱
java·后端·程序员
kfepiza6 小时前
Java的任务调度框架之Quartz 笔记250930
java·java ee