【问题标题】:Using C# to Load Excel Name Manager使用 C# 加载 Excel 名称管理器
【发布时间】:2021-12-18 12:27:22
【问题描述】:

我尝试使用 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();
        }

【问题讨论】:

  • Google 显示了一些关于 epplus 中不允许有效字符的错误的点击。您使用的是最新版本的 epplus 吗?

标签: c# excel epplus


【解决方案1】:

我阅读了 EPPlus 课程 如果名称管理器中有任何无效名称,我似乎无法使用 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);
    }

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-08-16
    • 2012-05-21
    • 2021-06-19
    • 1970-01-01
    • 2015-02-09
    相关资源
    最近更新 更多