草庐IT

excel-2013

全部标签

c# - 如果未安装 Excel,如何创建 Excel 实例

在我的C#应用程序中,在ExcelInteropdll(作为引用)的帮助下,我正在读/写excel文件。如果我将此程序移动到未安装office/excel的系统(想想干净的机器),我会遇到以下错误。System.Runtime.InteropServices.COMException(0x80040154):RetrievingtheCOMclassfactoryforcomponentwithCLSID{00024500-0000-0000-C000-000000000046}failedduetothefollowingerror:80040154Classnotregistere

c# - 如果未安装 Excel,如何创建 Excel 实例

在我的C#应用程序中,在ExcelInteropdll(作为引用)的帮助下,我正在读/写excel文件。如果我将此程序移动到未安装office/excel的系统(想想干净的机器),我会遇到以下错误。System.Runtime.InteropServices.COMException(0x80040154):RetrievingtheCOMclassfactoryforcomponentwithCLSID{00024500-0000-0000-C000-000000000046}failedduetothefollowingerror:80040154Classnotregistere

c# - VSTO:在主 Excel 线程上调用

我在Excel工作表上有一个按钮,它启动一个新线程来进行一些处理。如果我想对Excel进行任何更改(例如,使用Worksheet.Range("A1").Value="info";将数据写入单元格),我想我必须使用主UI线程.如何做到这一点?通常在Winforms中,我会在控件上调用Invoke,但是Excel.Application或Worksheet或Range对象没有Invoke方法。 最佳答案 这项工作“不需要”在UI线程上完成,.net会为您整理调用,但如果您从后台线程重复调用,则可能会遇到性能问题。但要具体回答您的问题,

c# - VSTO:在主 Excel 线程上调用

我在Excel工作表上有一个按钮,它启动一个新线程来进行一些处理。如果我想对Excel进行任何更改(例如,使用Worksheet.Range("A1").Value="info";将数据写入单元格),我想我必须使用主UI线程.如何做到这一点?通常在Winforms中,我会在控件上调用Invoke,但是Excel.Application或Worksheet或Range对象没有Invoke方法。 最佳答案 这项工作“不需要”在UI线程上完成,.net会为您整理调用,但如果您从后台线程重复调用,则可能会遇到性能问题。但要具体回答您的问题,

c# - 如何以编程方式检查电脑上是否存在 MS Excel?

我有一个应用程序需要MSExcel才能运行,否则它会崩溃。所以我想检查并警告用户,以防用户计算机上未安装Excel。我该怎么做? 最佳答案 TypeofficeType=Type.GetTypeFromProgID("Excel.Application");if(officeType==null){//noExcelinstalled}else{//Excelinstalled} 关于c#-如何以编程方式检查电脑上是否存在MSExcel?,我们在StackOverflow上找到一个类似的

c# - 如何以编程方式检查电脑上是否存在 MS Excel?

我有一个应用程序需要MSExcel才能运行,否则它会崩溃。所以我想检查并警告用户,以防用户计算机上未安装Excel。我该怎么做? 最佳答案 TypeofficeType=Type.GetTypeFromProgID("Excel.Application");if(officeType==null){//noExcelinstalled}else{//Excelinstalled} 关于c#-如何以编程方式检查电脑上是否存在MSExcel?,我们在StackOverflow上找到一个类似的

c# - 无法将 'microsoft.Office.Interop.Excel.ApplicationClass' 类型的 COM 对象转换为 'microsoft.Office.Interop.Excel.Application'”

我正在尝试从C#控制台应用程序中的Excel中捕获一些数据。我得到了错误UnabletocastCOMobjectoftype'microsoft.Office.Interop.Excel.ApplicationClass'to'microsoft.Office.Interop.Excel.Application'"此代码使用了“MicrosoftExcel12.0对象库”,并且我包含了对“Microsoft.Office.Interop.Excel”的引用。我对这个网站进行了一些挖掘,发现了Interoptypecannotbeembedded,但我对它的理解还不足以实现所建议的解决

c# - 无法将 'microsoft.Office.Interop.Excel.ApplicationClass' 类型的 COM 对象转换为 'microsoft.Office.Interop.Excel.Application'”

我正在尝试从C#控制台应用程序中的Excel中捕获一些数据。我得到了错误UnabletocastCOMobjectoftype'microsoft.Office.Interop.Excel.ApplicationClass'to'microsoft.Office.Interop.Excel.Application'"此代码使用了“MicrosoftExcel12.0对象库”,并且我包含了对“Microsoft.Office.Interop.Excel”的引用。我对这个网站进行了一些挖掘,发现了Interoptypecannotbeembedded,但我对它的理解还不足以实现所建议的解决

c# - 如何使用 Excel Interop 保存/覆盖现有 Excel 文件 - C#

有没有一种方法可以通过excel互操作将更改保存到excel电子表格(在这种情况下,我正在向其中添加一个工作表)而不提示用户是否要用更改覆盖现有文件。我什至不希望用户看到电子表格在我的应用程序中打开,因此弹出一个消息框询问他们是否要覆盖文件似乎非常不合适并且可能会让用户感到困惑。我正在使用workbook.SaveAs(fileloaction)方法。这里是我为excel互操作初始化COM引用对象的地方。privateExcel.Applicationapp=null;privateExcel.Workbookworkbook=null;publicExcel.WorkbookWork

c# - 如何使用 Excel Interop 保存/覆盖现有 Excel 文件 - C#

有没有一种方法可以通过excel互操作将更改保存到excel电子表格(在这种情况下,我正在向其中添加一个工作表)而不提示用户是否要用更改覆盖现有文件。我什至不希望用户看到电子表格在我的应用程序中打开,因此弹出一个消息框询问他们是否要覆盖文件似乎非常不合适并且可能会让用户感到困惑。我正在使用workbook.SaveAs(fileloaction)方法。这里是我为excel互操作初始化COM引用对象的地方。privateExcel.Applicationapp=null;privateExcel.Workbookworkbook=null;publicExcel.WorkbookWork