DataTable中的FileInfo无法正常工作

时间:2013-01-21 19:57:30

标签: c# .net datatable

我有两个comboBoxes。首先我选择Brand,在第二个我选择模型。我还想根据模型选择显示picture。在我添加FileInfo列之前,一切似乎都有效。现在代码无效(我甚至无法选择品牌和型号 - comboboxes are empty)。出了什么问题:

        dtCategories = new DataTable();
        dtCategories.Columns.Add("CategoryID", typeof(int));
        dtCategories.Columns.Add("CategoryName", typeof(string));

        dtCategories.Rows.Add(0, "--Select--");
        dtCategories.Rows.Add(1, "Audi");
        dtCategories.Rows.Add(2, "BMW");
        dtCategories.Rows.Add(3, "Mercedes");

        dtItems = new DataTable();
        dtItems.Columns.Add("ItemID", typeof(int));
        dtItems.Columns.Add("ItemName", typeof(string));
        dtItems.Columns.Add("CategoryID", typeof(int));
        dtItems.Columns.Add("Obrazek", typeof(FileInfo));

        dtItems.Rows.Add(2, "A1", 1, "a1.jpeg");
        dtItems.Rows.Add(3, "A3", 1, "a3.jpeg");
        dtItems.Rows.Add(4, "A4", 1, "a5.jpeg");
        dtItems.Rows.Add(5, "Seria 1", 2, "bmw1.jpeg");
        dtItems.Rows.Add(6, "Seria 2", 2, "bmw3.jpeg");
        dtItems.Rows.Add(7, "Seria 3", 2, "bmw5.jpeg");
        dtItems.Rows.Add(8, "C Klasa", 3, "C Klasa.jpeg");
        dtItems.Rows.Add(9, "E Klasa", 3, "E Klasa.jpeg");
        dtItems.Rows.Add(10, "S Klasa", 3, "S Klasa.jpeg");


        cbCategory.DisplayMember = "CategoryName";
        cbCategory.ValueMember = "CategoryID";
        cbCategory.DataSource = dtCategories;

并且:

        private void cbCategory_SelectedIndexChanged(object sender, EventArgs e)
        {
        int categoryId = Convert.ToInt32(cbCategory.SelectedValue);
        if (categoryId > 0)
        {
            DataTable dtTemp = dtItems.Select(string.Format("CategoryID = {0}",  categoryId)).CopyToDataTable();

            DataRow drTemp = dtTemp.NewRow();
            drTemp["ItemID"] = 0;
            drTemp["ItemName"] = "--Select--";
            drTemp["CategoryID"] = 0;

            dtTemp.Rows.InsertAt(drTemp, 0);

            cbItems.DisplayMember = "ItemName";
            cbItems.ValueMember = "ItemID";
            cbItems.DataSource = dtTemp;
            pictureBox1.Image = Image.FromFile(dtTemp.Columns[3].ToString());

        }
        else if (cbItems.DataSource != null)
        {
            cbItems.SelectedIndex = 0;
        }
    }

2 个答案:

答案 0 :(得分:1)

FileInfo不是DataTable列的有效数据类型。有关详细信息,请参阅DataColumn.DataType Property

你收到某种例外吗?

可能是您的图片路径不正确。 您可以尝试使用此代码,这可能更容易调试:

var imagePath = dtTemp.Columns[3].ToString();
if (File.Exists(imagePath))
{
    var image = Image.FromFile(imagePath);
    pictureBox1.Image = image;
}
else
{
    throw new FileNotFoundException(); 
    // of course something more subtle is advisable
}

答案 1 :(得分:0)

问题不在于第4列的数据类型是FileInfo。它是在添加行时不提供一个,而是为第4列提供string类型。做

dtItems.Rows.Add(2, "A1", 1, new FileInfo("a1.jpeg"));
dtItems.Rows.Add(3, "A3", 1, new FileInfo("a3.jpeg"));
//etc..

也就是说,FileInfo通常不适合DataTable。对于ur自定义表,它可能有效,但从db直接加载到该数据表时将不兼容。但是你的数据表可以正常DataSource

cbItems.DataSource = dtItems; //fine in your case.