c# - VSTO C# Excel 工作簿所有工作表
问题描述
我正在使用 C# VSTO 在目录中的所有 Excel 文件中进行文本替换。目前,我的代码有效,但仅适用于每个 Excel 文件的活动工作表(第一个工作表)。如何对 Excel 文件中的所有现有工作表执行此操作:
public void runFiles(string _path)
{
string path = _path;
object m = Type.Missing;
var xlApp = new Microsoft.Office.Interop.Excel.Application();
DirectoryInfo d = new DirectoryInfo(path);
FileInfo[] listOfFiles_1 = d.GetFiles("*.xlsx*").ToArray();
FileInfo[] listOfFiles_2 = d.GetFiles("*.xls*").ToArray();
FileInfo[] listOfFiles = listOfFiles_1.Concat(listOfFiles_2).ToArray();
xlApp.DisplayAlerts = false;
foreach (FileInfo file in listOfFiles)
{
var xlWorkBook = xlApp.Workbooks.Open(file.FullName);
Excel.Worksheet xlWorkSheet = xlWorkBook.Worksheets;
// get the used range.
Excel.Range r = (Excel.Range)xlWorkSheet.UsedRange;
// call the replace method to replace instances.
bool success = (bool)r.Replace(
"Engineer",
"Designer",
Excel.XlLookAt.xlWhole,
Excel.XlSearchOrder.xlByRows,
true, m, m, m);
xlWorkBook.Save();
xlWorkBook.Close();
}
xlApp.Quit();
Marshal.ReleaseComObject(xlApp);
}
xlWorkBook.ActiveSheet
只抓取唯一的第一张纸。我试过xlWorkBook.Worksheets
了,但我得到一个错误Cannot implicitly convert type 'Microsoft.Office.Interop.Excel.Sheets' to 'Microsoft.Office.Interop.Excel.Worksheet'. An explicit conversion exists (are you missing a cast?)
解决方案
Worksheets
属性是工作表的集合。所以你只需要遍历它。
foreach (Excel.Worksheet xlWorkSheet in xlWorkBook.Worksheets)
{
// get the used range.
Excel.Range r = (Excel.Range)xlWorkSheet.UsedRange;
// call the replace method to replace instances.
bool success = (bool)r.Replace(
"Engineer",
"Designer",
Excel.XlLookAt.xlWhole,
Excel.XlSearchOrder.xlByRows,
true, m, m, m);
}
推荐阅读
- javascript - react-router-dom:点击链接无限添加到Url的路由
- sql - Vertica 字符串时区转换
- javascript - Javascript 代码在 Safari(桌面和移动设备)上不起作用
- matlab - 如何在输入“N”乘“N”矩阵的中心找到“M”乘“M”子矩阵?(在 Matlab 中)
- r - 如何将许多因素循环到一个函数中
- mysql - 通过检查其他行中的值从 JOIN 表中获取结果
- amazon-web-services - APIG/Lambda 用于托管多个微服务
- xamarin - 如果在 ListView Xamarin Forms 中找不到图像跳过记录
- python - 为什么在创建类实例后不能为属性赋值?
- javascript - Javascript - 等待超长循环的正确方法?