![](/img/trans.png)
[英]c# Add new name in MS Excel name manager using value not coordinates
[英]Using C# to Load Excel Name Manager
我试图使用 C# 加载 Excel 名称管理器,但是,名称包含无效字符,如“\0”。 如何处理? 我什至不能'var name = pkg.Workbook.Names;'。
像这样的错误: System.ArgumentException:“名称 \0 包含无效字符”
using (ExcelPackage pkg = new ExcelPackage(filePatha))
{
var name = pkg.Workbook.Names;
foreach (ExcelNamedRange excelNamedRange in name)
{
Console.WriteLine($"IsNameHidden:{excelNamedRange.IsNameHidden}\n" +
$"Name:{excelNamedRange.Name}\n" +
$"Address:{excelNamedRange.Address}\n" +
$"Formula:{excelNamedRange.Formula}\n" +
$"Text:{excelNamedRange.Text}\n" +
$"Value:{excelNamedRange.Value}\n" +
$"FullAddressAbsolute:{excelNamedRange.FullAddressAbsolute}\n" +
$"---------------------------------\n");
}
Console.Read();
}
我阅读了 EPPlus class 如果名称管理器中有任何无效名称,我似乎无法使用 ExcelNamedRangeCollection。 我已经用 OpenXML 解决了这个问题。
/// <param name="Name">The name</param>
/// <param name="Range">The range</param>
/// <returns></returns>
public ExcelNamedRange Add(string Name, ExcelRangeBase Range)
{
if (!ExcelAddressUtil.IsValidName(Name))
throw new ArgumentException("Name contains invalid characters or is not valid.");
if (this._wb != Range._workbook)
throw new InvalidOperationException("The range must be in the same package. ");
return this.AddName(Name, Range);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.