繁体   English   中英

使用 C# 加载 Excel 名称管理器

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM