Range Validation with Excel using C#(使用 C# 使用 Excel 进行范围验证)
问题描述
在 C# 中的 Excel 中,如何创建一个可以对项目进行排序的组合,当单击其中一个项目时,该项目单独出现?
In Excel in C# how does one create a combo where it can sort the items and when one of them is clicked, the item appears alone?
推荐答案
如果你想为此目的使用验证,我编写了以下方法来添加验证和一个小的信息框,当用户点击细胞:
if you want to use a validation for that purpose the following method was written by me to add a Validation and a small Infobox that appears when the user clicks on the cell:
/// <summary>
/// Adds a small Infobox and a Validation with restriction (only these values will be selectable) to the specified cell.
/// </summary>
/// <param name="worksheet">The excel-sheet</param>
/// <param name="rowNr">1-based row index of the cell that will contain the validation</param>
/// <param name="columnNr">1-based column index of the cell that will contain the validation</param>
/// <param name="title">Title of the Infobox</param>
/// <param name="message">Message in the Infobox</param>
/// <param name="validationValues">List of available values for selection of the cell. No other value, than this list is allowed to be used.</param>
/// <exception cref="Exception">Thrown, if an error occurs, or the worksheet was null.</exception>
public static void AddDataValidation(Worksheet worksheet, int rowNr, int columnNr, string title, string message, List<string> validationValues)
{
//If the message-string is too long (more than 255 characters, prune it)
if (message.Length > 255)
message = message.Substring(0, 254);
try
{
//The validation requires a ';'-separated list of values, that goes as the restrictions-parameter.
//Fold the list, so you can add it as restriction. (Result is "Value1;Value2;Value3")
//If you use another separation-character (e.g in US) change the ; appropriately (e.g. to the ,)
string values = string.Join(";", validationValues);
//Select the specified cell
Range cell = worksheet.Cells[rowNr, columnNr];
//Delete any previous validation
cell.Validation.Delete();
//Add the validation, that only allowes selection of provided values.
cell.Validation.Add(XlDVType.xlValidateList, XlDVAlertStyle.xlValidAlertStop, XlFormatConditionOperator.xlBetween, values, Type.Missing);
cell.Validation.IgnoreBlank = true;
//Optional put a message there
cell.Validation.InputTitle = title;
cell.Validation.InputMessage = message;
}
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 cell Row:{0}, Column:{1}, Message: {2}", rowNr, columnNr, message), exception);
}
}
如果您不需要信息框,只需省略出现变量标题或消息的部分即可.
If you don't need the Infobox, just leave out the parts where the variables title or message appear.
这篇关于使用 C# 使用 Excel 进行范围验证的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用 C# 使用 Excel 进行范围验证
- 如何用自己压缩一个 IEnumerable 2022-01-01
- WebMatrix WebSecurity PasswordSalt 2022-01-01
- 带有服务/守护程序应用程序的 Microsoft Graph CSharp SDK 和 OneDrive for Business - 配额方面返回 null 2022-01-01
- C# 中多线程网络服务器的模式 2022-01-01
- C#MongoDB使用Builders查找派生对象 2022-09-04
- MoreLinq maxBy vs LINQ max + where 2022-01-01
- 良好实践:如何重用 .csproj 和 .sln 文件来为 CI 创建 2022-01-01
- 输入按键事件处理程序 2022-01-01
- 在哪里可以找到使用中的C#/XML文档注释的好例子? 2022-01-01
- Web Api 中的 Swagger .netcore 3.1,使用 swagger UI 设置日期时间格式 2022-01-01