- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
背景:
我在工作中为我的旧硬盘干杯,现在正在买一个新硬盘。这样我就必须重建我的机器。我的经理在他借用的笔记本电脑上安装了 Windows 7,在我的机器无法使用时我一直在使用这台笔记本电脑。但我遇到了一个问题。
我们有相当多的应用程序使用 Microsoft.Office.Interop.Excel 引用。到目前为止,我已经克服了一些错误,但最近几天我一直遇到的错误(我的机器实际上在第一次重建后遇到了硬盘驱动器故障)并且无法找到修复方法。我已经搜索了此错误,但找不到任何人在 Windows 7 上遇到此问题,尽管我尝试了 Windows Server 2008 的其他修复程序但无济于事。
如果我不能解决这个问题,我将无法使用 Windows 7,并且想知道在我重建机器之前只需删除它并重新启动(第三次)。
问题:
操作系统:Windows 7 企业版
错误消息:HRESULT 异常:0x800A03EC
代码:
Private m_xls As Microsoft.Office.Interop.Excel.Application
Private m_wkbk As Microsoft.Office.Interop.Excel.Workbook
Private m_wksht As Microsoft.Office.Interop.Excel.Worksheet
m_xls = New Application
m_xls.Visible = False : m_xls.DisplayAlerts = False
m_wkbk = m_xls.Workbooks.Open(Me.FilePath)
m_wksht = CType(m_wkbk.ActiveSheet, Worksheet)
'...Write some data...'
m_wkbk.SaveAs(Me.FilePath, XlFileFormat.xlWorkbookNormal, Missing.Value, Missing.Value, False, False, XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value)
错误发生在最后一行。
到目前为止我尝试过的:
我只是想看看是否有其他人遇到过这个问题,因为 Windows 7 是新的。我可以选择 Server 2008,但在我告诉我的经理这不起作用之前,我希望能有一些可靠的理由。
谢谢你,杰夫
最佳答案
注意:这需要稍微精简一下,因为它是我在内部 wiki 上所做的所有修复的汇编,但我不确定哪些更改子集使它起作用,所以我将全部包含在内。
解决方案:
以下更改可能是解决此问题的超集。
-运行 DCOMCNFG.exe 并导航至“组件服务>计算机>我的电脑”。
-右键单击“我的电脑”,然后单击“属性”。
- 打开“COM 安全”选项卡。为列出的每个按钮添加您的帐户(“访问权限”和“启动和激活权限”下的“编辑限制...”和“编辑默认...”按钮)。为您的帐户提供所有访问选项。单击“应用”,然后单击“确定”。
-仍在 DCOMCNFG 中时,展开“我的电脑”链接并打开“DCOM Config”文件夹。
- 右键单击“Microsoft Excel 应用程序”并选择“属性”。
- 在“安全”选项卡下,选择“启动和激活权限”和“配置权限”的“自定义”选项。对于两者,请单击“编辑...”按钮。授予您的帐户访问所有内容的权限。
- 仍在“Microsoft Excel 应用程序”的“属性”中,转到“身份”选项卡。
-选择“交互式用户”选项。
- 单击“应用”,然后单击“确定”。
-重新启动计算机。
-尝试以下DCOMCNFG 和 ApplicationPoolIdentity 更改。
-以管理员身份运行命令提示符。
-导航到 c:\Windows\System32\inetsrv> 并运行 'appcmd set config -section:asp -enableParentPaths:true'
或者,您可以使用 .SaveCopyAs(),尽管这可能仍然无法解决问题并且需要更改代码。
DCOMCNFG 对于 Windows 7:
此错误发生在“Excel app = New Application();”上来电
此链接详细介绍了如何修复 XP/Server 2003 的问题,但也可以适用于 Windows 7:http://blog.crowe.co.nz/archive/2006/03/02/589.aspx
我没有/无法找到“ASPNET”帐户。您必须检查应用程序池以找出应用程序正在运行的内容。
为此,请进入“计算机管理>服务和应用程序>Internet信息服务>应用程序池”
右键单击相应的应用程序池并选择“高级设置”。在“流程模型>身份”下,您可以找到它正在运行的帐户。我的是“ApplicationPoolIdentity”,但我也找不到,所以我将其更改为“网络服务”,如 Windows Server 2003。
设置完成后,运行 DCOMCNFG.exe。导航至“组件服务>计算机>我的电脑>DCOM 配置”。
找到并右键单击“Microsoft Excel 应用程序”,然后选择“属性”。选择“安全”选项卡。在“启动和激活权限”下选择“自定义”,然后单击“编辑”。
然后点击“添加...”按钮。
输入适当帐户的名称,在本例中为“网络服务”,然后单击“检查名称”。然后点击“确定”。
返回“启动和激活权限”页面,突出显示“网络服务”帐户,然后选中“本地启动”和“本地激活”复选框。然后单击“确定”。
关于.net - Windows 7 .net Excel .SaveAs() 来自 HRESULT : 0x800A03EC 的错误异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1981395/
有人可以帮我解码这个 HResult 吗?这是什么意思?我知道消极代表着失败。剩下的 10 位怎么样? 我引用了MSDN HResult文章here ,但我不确定如何确定我的设施和代码位是什么。 更多
假设我有一个设计得不太好的 COM 接口(interface),并且某些类在逻辑上无法实现它的方法之一。 例如,有一些方法,如 Explode()许多类只是不能合理地“爆炸”,但仍然必须实现该方法并需
嗨,我设计了一个控制台应用程序来测试我的 C++ 项目(.Net Framework 3.5)。我为此应用程序创建了一个设置并将其安装在虚拟机上以进行测试。但是每当我在虚拟机上运行这个已安装的应用程序
是否有解释错误代码的列表。 Eks:HRESULT:0x81070215 没有告诉我什么时候出错了? 最佳答案 WinError.h 我的机器上有以下路径,你的也类似: C:\Program File
我正在开发一个供 Microsoft .NET 和 COM 组件使用的 Microsoft .NET 程序集。我正在编写托管代码,并且必须指出何时为类中的方法指定了不正确的参数。当出现参数异常时,我需
我在 IUnknown 派生的 COM 接口(interface)中有一个函数: HRESULT GetPassword( [in] long bufferLength, [out] WCHAR* b
类似问题was asked before ,但我还没有在那里找到一些答案。 据我所知,为了制作自定义 HRESULT 代码,我创建了一个 .mc 文件,我在其中描述代码,然后编译它并获得一个 .h 文
我已经有一个使用大量 COM 和 HRESULTS 的项目。无论如何,我想知道是否可以定义自己的 HRESULT,并且能够将 FormatMessage() 用于我们自己的 HRESULT? 我翻遍了
我发现有时在 IO 操作中常见 IOException被抛出。我可以使用 Marshal.GetHRForException(Exception e)方法(找到 here )以确定具体的错误代码。之后
感谢任何帮助: 我正在 VS2010 中开发一个与 Excel 交互的 C#.Net 应用程序。该应用程序在我的本地计算机上正常运行。但是,上传到远程 Windows 2003 服务器会破坏应用程序。
我在使用 Windows.Media.Capture 命名空间中的 MediaCapture 对象时收到此异常消息 Exception from HRESULT: 0xC00D36B4。当我尝试使用
十进制:143196173 十六进制:0x889000D 调用 IAudioSessionControl2->GetProcessId() 的结果. GetLastError = 126* Messa
我只是花了 way 太长时间试图诊断为什么在下面的代码片段中,ProcessEvent() 方法似乎忽略了 false 我为 aInvokeEventHandler 传入的值: HRESULT CEv
以下 EndDraw() 函数返回 HRESULT 错误代码: http://msdn.microsoft.com/en-us/library/windows/desktop/dd371924%28v
我需要将 HRESULT 值作为命令行参数传递给程序。我本来打算通过传递十六进制值来做到这一点,例如: >receiver.exe 0x80048836 我正在尝试使用 wcstol 将此字符串表示形
我希望能够执行与 FormatMessage 等效的操作 - 生成用于调试甚至运行时构建的文本消息,可以报告一些常见的 HRESULT,甚至吐出诸如严重性、它的功能等信息是,可能还有错误代码的描述。
为什么在定义错误/HRESULT 处理/日志记录时会选择或不选择使用宏? 我正在处理一个通过接口(interface)调用的错误处理类,因此我可以使用 Boost 共享指针在我需要的时间和地点调用该类
这个问题在这里已经有了答案: Is there a way to get the string representation of HRESULT value using win API? (4 个
我在 Windows Vista 上使用 .NET Framework 6.0 版。我最近安装了一个显示图表的程序。当我打开它时,我收到一条来自 Microsoft .NET 框架的错误消息: Cla
我想测试下面的代码: private bool TestException(Exception ex) { if ((Marshal.GetHRForException(ex) & 0xFFF
我是一名优秀的程序员,十分优秀!