我正在编写一个程序来将一组用户数据添加到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));
}
}
错误是这样的:
打开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删除验证列表?
谢谢!
答案 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");