将wpf datagrid控件中的内容导入数据表

时间:2013-09-25 22:53:39

标签: c# sql wpf datagrid datatable

我正在尝试创建一个应用程序,我将一些数据输入某些控件(开始日期和结束日期工资周),然后用户从我们的工资程序中选择一个csv提取。然后,应用程序将控件和csv文件中的数据合并到一个数据表中,然后将其设置为wpf datagrid视图的datacontxct。

this.dgCSVData.DataContext = oDS.Tables[0].DefaultView;

因此我坚持认为数据网格现在已经绑定了(这是一个问题而非声明)这是一个屏幕截图screenshot of loaded data

数据网格是我想要附加数据的sql数据库中数据表的“形状”。但是,数据表是在私有事件处理程序CSV_Load_Click中创建的,下面是代码块。

我希望做的是设置另一个按钮事件处理程序调用“上传数据”并将数据表(oDS.Tables [0] .DefaultView)传递给DAL层,以便读取并附加到sql数据库表,问题是我如何使数据表可用,我是否应该创建一个类来匹配我的数据行,然后创建一个行的公共列表?

private void CSV_Load_Click(object sender, RoutedEventArgs e)
{
    //Turn on upload button
    btUpload.IsEnabled = true;

    //To load and display CSV data
    //string filename = txFilePath.Text;
    string delimStr = ",,";
    char[] delimiter = delimStr.ToCharArray();
    string strFilePath = txFilePath.Text;
    DataSet oDS = new DataSet();
    string strFields = null;
    DataTable oTable = new DataTable();
    DataRow oRows = null;
    Int32 intCounter = 0;
    oDS.Tables.Add("Property");
    StreamReader oSR = new StreamReader(strFilePath);
    //Go to the top of the file
    oSR.BaseStream.Seek(0, SeekOrigin.Begin);
    string File = fileTest;
    //System.Windows.MessageBox.Show(File.ToString());

    //Add in the Header Columns check if headers in first row
    if (rbYes.IsChecked==true)
        // action for headers in row 1
    {
        foreach (string strFields_loopVariable in oSR.ReadLine().Split(delimiter))
        {
            strFields = strFields_loopVariable;
            oDS.Tables[0].Columns.Add(strFields);
        }
    }
    else
    {
        if (File==@"CHHOURS.CSV")
        {
            string TitleHeaders = "Wage_Year,Wage_Start_Date,Wage_End_Date,Tax Week,Wk_No,Clock,Surname,Initial,Dept,Dept_Hours,Other_Hours,Total_Hours,OT_Hours,";
            foreach (string strFields_loopVariable in TitleHeaders.Split(delimiter))
            {
                strFields = strFields_loopVariable;
                oDS.Tables[0].Columns.Add(strFields);
            }  
        }           
        else
        {
            Int32 i = 0;
            foreach (string strFields_loopVariable in oSR.ReadLine().Split(delimiter))
            {
                string ColumLetter = "abcdefghijklmnopqrstuvwxyz";

                strFields = ColumLetter[i].ToString();
                oDS.Tables[0].Columns.Add(strFields);
                i += 1;
            }
        }
    } 


    //String request = oSR.ReadToEnd();
    //Now add in the Rows
    oTable = oDS.Tables[0];
    while ((oSR.Peek() > -1))
    {
        oRows = oTable.NewRow();

        if (File == @"CHHOURS.CSV")
        {
            oRows[intCounter] = cbWageYear.Text;
            intCounter = intCounter + 1;
            oRows[intCounter] = dpStartDate.SelectedDate;
            intCounter = intCounter + 1;
            oRows[intCounter] = dpEndDate.SelectedDate;
            intCounter = intCounter + 1;
            oRows[intCounter] = cBTaxWeek.SelectedIndex;

            intCounter = intCounter + 1;
        }
        foreach (string strFields_loopVariable in oSR.ReadLine().Split(delimiter))
        {
            strFields = Convert.ToString(strFields_loopVariable);
            if (intCounter < 20)
            {
                oRows[intCounter] = strFields;
                intCounter = intCounter + 1;
            }
            else
            {

            }
        }

        intCounter = 0;
        oTable.Rows.Add(oRows);
    }

    this.dgCSVData.DataContext = oDS.Tables[0].DefaultView;
}

1 个答案:

答案 0 :(得分:0)

好的,所以我今天早上醒来时有了一个想法并且它有效。哇!

我所做的就是在我班级的构造函数之前将我的数据集声明为public。现在可能有一种“更好”的方式,但这对我有用。我已经能够从我的DAL调用我的更新方法并创建一个datareader,所以现在只需更新到sql,然后修复错误。

我几乎快乐:)

这是代码

 public partial class MainWindow : Window
{



    public List<TaxWeek> LTaxWeeks { get; set; }

    public TaxWeek SelectedTaxWeek { get; set; }

    **public DataSet oDS = new DataSet();**


    public MainWindow()

    {
        InitializeComponent();
    }