首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用powershell变量设置Excel工作表名称?

如何使用powershell变量设置Excel工作表名称?
EN

Stack Overflow用户
提问于 2020-02-13 19:23:03
回答 1查看 763关注 0票数 1

我试图使用一个变量来设置一个带有Powershell的excel工作表名,但是得到了以下错误:

代码语言:javascript
复制
Exception from HRESULT: 0x800A03EC
At line:14 char:1
+ $ws.Name = $RequestTitle
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : OperationStopped: (:) [], COMException
    + FullyQualifiedErrorId : System.Runtime.InteropServices.COMException

下面是代码的一个片段:

代码语言:javascript
复制
# create new excel object 
$excel = New-Object -ComObject excel.application

# show the excel object 
$excel.visible = $True

# add a workbook 
$workbook = $excel.Workbooks.Add()

# create a variable referencing the first sheet of the wb
$ws= $workbook.Worksheets.Item(1)

# change the name of the sheet 
$ws.Name = $NewSheetName

但是,当我做这样的事情:$ws.Name = "some string",它工作良好,没有错误。我也尝试过使用$NewSheetName.ToString()方法,但没有结果。

引用变量来命名工作表的最佳方法是什么?任何帮助都将不胜感激!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-02-13 19:38:25

使用这样的语句就可以解决这个问题。将引号放在变量名的周围。

代码语言:javascript
复制
# change the name of the sheet 
$ws.Name = "$NewSheetName"

我不知道为什么,但是excel工作表名需要一个引号中的字符串,即使使用一个明显是字符串的变量。

Note

使用powershell v5和Office 2013进行测试,Office 365,没有引用的$variable代码工作良好。不确定是什么导致了需要在变量名周围使用double quotes的问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60215091

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档