C#将验证列表添加到excel错误

时间:2015-02-24 06:31:09

标签: c# excel validation

我正在编写一个程序来将一组用户数据添加到excel文件中。 一些单元格需要有一个下拉列表,这是一个验证列表。数据列表由用户提供。

使用C#代码将数据导出到Excel时,有时数据会导致程序,但有时不会。

添加数据时,程序端没有错误

validationValues.Add("Interface Phase 1 Cycle3");
validationValues.Add("Performance Testing");
validationValues.Add("Pre SIT (HLB)");
validationValues.Add("Pre-SIT FE (EtoE) Phase1 C1");
validationValues.Add("Sanity Test(HLB)");
validationValues.Add("SIT Cycle 1 (HLB)");
validationValues.Add("SIT Cycle 2 (HLB)");
validationValues.Add("SIT Cycle 3 (HLB)");
validationValues.Add("SIT FE (EtoE) Phase1 C1");
validationValues.Add("SIT FE (EtoE) Phase1 C2");
validationValues.Add("SIT FE (EtoE) Phase1 C3");
validationValues.Add("SIT Sanity Check");
validationValues.Add("SIT STB Cycle 1");
validationValues.Add("SIT STB Cycle 2");
validationValues.Add("SIT STB Cycle 3");
validationValues.Add("SIT STB Sanity Check");
validationValues.Add("SIT STB User Interface Issues");
validationValues.Add("SIT WOG Phase1 C1");
validationValues.Add("SIT WOG Phase1 C2");
validationValues.Add("SIT WOG Phase1 C3");
if (validationValues.Count != 0)
    AddDataValidation(xlWorkSheet, validationValues, "R:R");
validationValues.Clear();

在AddDataValidation函数中:

    private static void AddDataValidation(Excel.Worksheet worksheet, List<string> validationValues, string col)
    {
        try
        {

            string values = string.Join(",", validationValues);
            Excel.Range column = worksheet.UsedRange.Columns[col, Type.Missing];
            column.Validation.Delete();
            column.Validation.Add(XlDVType.xlValidateList, XlDVAlertStyle.xlValidAlertInformation, XlFormatConditionOperator.xlBetween, values, Type.Missing);
            column.Validation.IgnoreBlank = true; 

        }
        catch (Exception exception)
        {
            //This part should not be reached, but is used for stability-reasons
            throw new Exception(String.Format("Error when adding a Validation with restriction to the specified Column:{0}, Message: {1}", col, exception));

        }
    }

错误是这样的: Error 1 when open excel Error 2 when accept excel correction 打开excel文件后,它会删除验证功能,不会向单元格显示下拉列表。

XML文件内容如下: error025200_02.xml在文件中检测到错误C:\ Users \ wendylinlin \ Desktop \ Reports-Common20152241477_Defects.xlsx&#39;删除的功能:来自/xl/worksheets/sheet1.xml部分的数据验证

但是,如果我使用括号注释掉验证值,则表示不添加(或),验证工作正常,我可以在打开Excel后看到下拉列表。

我尝试进行字符串操作,替换所有&#34;(&#34;和&#34;)&#34;有空格,但它给出了同样的错误。其他一些字符串&#34; - &#34;和&#34;,&#34;也给出了类似的问题。但是,替换特殊字符对所有情况都没有帮助。

任何人都知道发生了什么?如何为excel提供正确的验证值并阻止excel删除验证列表?

谢谢!

1 个答案:

答案 0 :(得分:0)

我查了一些论坛讨论,发现Validation.Add函数只接受一个最多255个字符的列表。如果您希望列表中包含更多字符和项目,唯一的方法是将列表存储在Excel工作表中,并为列表指定一个特定范围。要隐藏用户的值,实际上我使用的是未使用的excel列并隐藏下拉列表值的列。 这是我发现解决此问题的唯一方法。

for (int valueNum = 0; valueNum < bug.Fields["Microsoft.VSTS.Common.CrimsonLogic.TargetVersion"].AllowedValues.Count; valueNum++)
{
    //use unused columns to add validation value
    xlWorkSheet.Cells[valueNum + 1, 27] = bug.Fields["Microsoft.VSTS.Common.CrimsonLogic.TargetVersion"].AllowedValues[valueNum].ToString();
}
//Column R is where I want the drop down list to be
ValidationValueCol = xlWorkSheet.UsedRange.Columns["R:R", Type.Missing];
ValidationValueCol.Validation.Delete();
strconfig = "='" + Sheetname+ "'!$AA$1:$AA$" + (bug.Fields["Microsoft.VSTS.Common.CrimsonLogic.TargetVersion"].AllowedValues.Count+1);
//Add the validation range with the pre-stored list
ValidationValueCol.Validation.Add(XlDVType.xlValidateList, XlDVAlertStyle.xlValidAlertStop, XlFormatConditionOperator.xlBetween, strconfig, Type.Missing);
ValidationValueCol.Validation.IgnoreBlank = true;
HideColumn(xlWorkSheet, "AA");