当Office PIA遭遇C# 4.0

2023-11-08 14:20
文章标签 c# office .net netcore 4.0 遭遇 pia

本文主要是介绍当Office PIA遭遇C# 4.0,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上回书说到,最近我在写一个Office PIA的程序。我先是写了一个独立的小工程,完美地实现了对Excel Workbook的各种操作,并且也反复作了测试。然后往我们真实的项目里合并。这里有个伏笔:我们team用的是Visual Studio 2008,而我个人用的是Visual Studio 2010。我没忘记在我的Visual Studio 2010工程里面把.Net Framework的版本设置为3.5。这个地方要跟我们实际的项目保持一致,这一点我还是很注意的。

谁曾想,合并的时候出了问题,编译出现一大堆错误。

比如说这个方法:

        /// <summary>/// Creates the excel doc./// </summary>/// <param name="fileName">the excel doc filename</param>public void CreateWorkbook(string fileName){try{this.CurrentWorkbook = this.Application.Workbooks.Add(Excel.XlWBATemplate.xlWBATWorksheet);this.LatestWorksheet = this.CurrentWorkbook.Sheets[1] as Excel.Worksheet;this.CurrentWorksheet = this.LatestWorksheet;string fullPath = this.GetActualFullPath(fileName);this.LatestWorksheet.SaveAs(fullPath,this.currentFileFormat,Type.Missing,Type.Missing,Type.Missing,Type.Missing);}catch (Exception ex){this.Close();throw ex;}}

这段代码,在Visual Studio 2010里面编译没有任何问题,在Visual Studio 2008里面编译时却出现了这样的错误:

Compile error: No overload for method 'SaveAs' takes '6' arguments ......

修改成这样的代码,才在Visual Studio 2008下编译通过(当然也能够在Visual Studio 2010下编译通过):

        /// <summary>/// Creates the excel doc./// </summary>/// <param name="fileName">the excel doc filename</param>public void CreateWorkbook(string fileName){try{this.CurrentWorkbook = this.Application.Workbooks.Add(Excel.XlWBATemplate.xlWBATWorksheet);this.LatestWorksheet = this.CurrentWorkbook.Sheets[1] as Excel.Worksheet;this.CurrentWorksheet = this.LatestWorksheet;string fullPath = this.GetActualFullPath(fileName);this.LatestWorksheet.SaveAs(fullPath,this.currentFileFormat,Type.Missing,Type.Missing,Type.Missing,Type.Missing,Excel.XlSaveAsAccessMode.xlExclusive,Type.Missing,Type.Missing,Type.Missing);}catch (Exception ex){this.Close();throw ex;}}

同样的问题多处出现。比如说Visual Studio 2010下能编译通过的这段代码:

        /// <summary>/// Create new worksheet and insert it after current worksheet./// </summary>/// <param name="worksheetName">name of the new worksheet</param>public void AddWorksheetAfter(object worksheetName){this.LatestWorksheet = this.CurrentWorkbook.Worksheets.Add(Type.Missing, worksheetName) as Excel.Worksheet;this.Save();}

在Visual Studio 2008下编译遭遇这样的错误:

Compile error: No overload for method 'Add' takes '2' arguments ......

改成下面这样才解决:

        /// <summary>/// Create new worksheet and insert it after current worksheet./// </summary>/// <param name="worksheetName">name of the new worksheet</param>public void AddWorksheetAfter(object worksheetName){this.LatestWorksheet = this.CurrentWorkbook.Worksheets.Add(Type.Missing, worksheetName, Type.Missing, Type.Missing) as Excel.Worksheet;this.Save();}

这是为什么呢?首先请不要疑神疑鬼,不要惊慌,要相信科学,遇到问题要广泛地借助Google和MSDN这两个好工具。微笑


Visual Studio 2008编译出错的地方,全都是出在Office PIA的Interop COM组件的可选参数之处。在Visual Studio 2010中,尽管我的.Net Framework版本选择的是3.5,但是由于Visual Studio 2010的编辑器本身支持C# 4.0的一些“语法糖”,C# 4.0对于COM组件的互操作性作了增强,支持了可选参数的省略,因此我在编程中省掉了那一大堆Type.Missing。这样,我在Visual Studio 2010下写的代码显得很简洁。当然也正是这些地方造成了在Visual Studio 2008下编译的困扰。


MSDN中相关的链接如下:


  • Named and Optional Arguments (C# Programming Guide) http://msdn.microsoft.com/en-us/library/dd264739.aspx


问题的查找与解决并不复杂。尽管这是由Visual Studio 2010的新特性给我造成的小麻烦,但是遇到这样的小麻烦,心情还是很愉悦的,我不认为这是什么坏事情。


这篇关于当Office PIA遭遇C# 4.0的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/370451

相关文章

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点