我有一个WFA用于动态恢复数据库。现在我有一个列表框,显示目录中的所有备份,但它也包含我想要访问的文件夹。这是列表框的代码:
private void PopulateListBox()
{
try
{
var dinfo = new DirectoryInfo(@"C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup");
var files = dinfo.GetFiles("*.bak");
foreach (var file in files)
{
listBox1.Items.Add(file.Name);
}
}
catch (Exception)
{
MessageBox.Show("The application could not find the directory to populate the List Box.");
}
}
目前我设置了一个组合框来显示备份中的不同文件夹:
private void PopulateComboBox()
{
string[] directory = Directory.GetDirectories(@"C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup");
foreach (string folder in directory)
{
comboBox1.Items.Add(folder);
}
}
当我单击组合框中的其他目录时,我要做的是更改列表框的内容。我有一个方法来实现我想要做的但我不知道如何编码。
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
listbox1.Clear()
//rest of the code would go here
}
如何根据我在组合框中的选择显示列表框中每个目录的内容?
答案 0 :(得分:1)
我更像是一个WPF人,但我很确定它的工作方式与此类似。
您想要处理其中一个“SelectionChanged”事件(SelectedIndexChanged,SelectedValueChanged或SelecitonChangeCommitted),并在处理程序中放置代码以检查组合框中选择的项目,并根据该选择重新填充列表框。 / p>
答案 1 :(得分:1)
这应该有用。
a)使你的populateListBox函数接受参数“dinfo”
private void PopulateListBox(string dname)
{
try
{
listBox1.Clear();
var dinfo = new DirectoryInfo(@"C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup\" + dname); //combine base folder with the folder from combobox
var files = dinfo.GetFiles("*.bak");
foreach (var file in files)
{
listBox1.Items.Add(file.Name);
}
}
catch (Exception)
{
MessageBox.Show("The application could not find the directory to populate the List Box.");
}
}
b)在您的selectedindexchanged方法中,将组合框中的选定值传递给PopulateListBox函数:
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
PopulateListBox(comboBox1.SelectedValue);
}
答案 2 :(得分:0)
我最终根据Yushatak的回应提出了我自己的解决方案。我创建了一个指向备份文件夹的全局字符串变量(这是应用程序启动时的默认目录),在组合框UI的属性中创建了一个集合,删除了我创建的组合框函数(因为它没有需要更长时间),然后在SelectionIndexChanged方法中使用一系列If语句来处理我想要访问的文件夹。
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
if (comboBox1.SelectedItem == "Backup")
{
string backup = @"C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup";
PopulateListBox(backup);
}
else if (comboBox1.SelectedItem == "Backups 2")
{
string backup = @"C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup\Backups 2";
PopulateListBox(backup);
}
else if (comboBox1.SelectedItem == "Backups 3")
{
string backup = @"C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup\Backups 3";
PopulateListBox(backup);
}
}