这是我为在 Excel 单元格中制作下拉列表而编写的方法,方法是从同一工作表/工作簿中的某个范围内获取可能的值。
private void MakeDropDownList(string strSrcSheetName, string strDestSheetName, string strSrcRange, string strDestCell)
{
var currentSheet = Application.Sheets[strDestSheetName];
var inv = Application.Sheets[strSrcSheetName];
var items = inv.Range[strSrcRange];
var list_items = new List<string>();
foreach (Excel.Range cell in items)
{
list_items.Add(cell.Value2.ToString());
}
Range xlsRange;
xlsRange = currentSheet.Range[strDestCell];
Excel.DropDowns xlDropDowns;
Excel.DropDown xlDropDown;
xlDropDowns = ((Excel.DropDowns)(currentSheet.DropDowns(Missing.Value)));
xlDropDown = xlDropDowns.Add((double)xlsRange.Left, (double)xlsRange.Top, (double)xlsRange.Width, (double)xlsRange.Height, true);
//Add item into drop down list
for (int i = 0; i < list_items.Count; i++)
{
xlDropDown.AddItem(list_items[i], i + 1);
}
}
要使用它,我可以像这样调用它:
MakeDropDownList("Units", "ReceiveBonds", "B1:B5", "E9:E18");
但是,最终的结果是这样的:
如您所见,下拉列表小于E
列宽,更糟糕的是,在我从下拉列表中选择一个值后,单元格保持其原始值,即Choose Unit
.
难道我做错了什么?
我想要的是:
- 要么让这个下拉列表看起来像 Excel 的常规验证下拉列表,要么。
- 能够触发事件将列表中的选定值设置到相应的单元格。