我正在尝试阅读文本格式,例如通过 Strikethough 属性
myworksheet.Cells[row, col].DisplayFormat.Style.Font.Strikethrough;
但是,无论实际的格式是什么,结果总是错误的。
在此之前,我使用以下方法读取了同一单元格的值:
myworksheet.Cells[row, col].Value;
并得到正确的值。
当我尝试使用调试器读取时,myworksheet.Cells[row, col].DisplayFormat.Style.Font.Strikethrough
我收到错误消息。
当我尝试使用调试器读取格式Font
并查看其属性时,我得到:
异常详情:
Strikethrough {System.Reflection.TargetInvocationException: Exception has been thrown by the target of an invocation. ---> System.Runtime.InteropServices.COMException: Old format or invalid type library. (Exception from HRESULT: 0x80028018 (TYPE_E_INVDATAREAD))
--- End of inner exception stack trace ---
at System.RuntimeType.InvokeDispMethod(String name, BindingFlags invokeAttr, Object target, Object[] args, Boolean[] byrefModifiers, Int32 culture, String[] namedParameters)
at System.RuntimeType.InvokeMember(String name, BindingFlags bindingFlags, Binder binder, Object target, Object[] providedArgs, ParameterModifier[] modifiers, CultureInfo culture, String[] namedParams)
at System.Dynamic.IDispatchComObject.GetMembers(IEnumerable`1 names)} System.Reflection.TargetInvocationException
我在 Windows 7 SP1 x64 操作系统上安装了 Office 2010 x86,并且我从 .NET 4.0 项目中引用 Microsoft.Office.Interop.Excel 版本 14。
我使用相同的库以编程方式创建了 .xlsx 文件,并通过 Excel 的 UI 手动添加了文本格式。
通过调试器(监视和立即)访问引发的异常提示库版本可能已过时,但是,版本 14 似乎是正确的版本(http://www.microsoft.com/en-us/download /details.aspx?id=3508)。
我错过了什么?