1

1.) ***好的,所以我有从 Excel 电子表格导入的 DataTable 并已填充。我想筛选 DataTable 并对每一行求和。我必须跳过第一列和第一行,因为它们是标签。我试图到达表中的每一行并将其汇总并输出到“行总计”列。当我尝试分配“数字”变量以尝试对每个单元格求和时,我得到一个“指定的无效强制转换”价值。

示例:
Row(0) --------ItemA......ItemB.......ItemC........ ......行总计

第 (1) 栏 公司 A .....12 ....12..................10........ ......34

2.)另外,我还没有达到它 - 我试图将它输出到 DataTable 中的最后一列存在潜在问题。

注明: dr[dt.Columns.Count - 1] = Convert.ToInt32(sum);

有什么想法或建议吗?

            DataRow dr = dt.NewRow();

            int sum = 0;
            dt.Columns.Add("Row Totals", typeof(int));

         for (int i = 0; i < dt.Columns.Count; i++)
            {
                if (dt.Columns[i].ColumnName == "Client")
                {
                    dt.Columns.Cast<DataColumn>().Skip(1);
                }
                else
                {
                    for (int j = 0; j < dt.Rows.Count - 1; j++)
                    {
                        dt.Rows.Cast<DataRow>().Skip(1);

                       int number =0;

                       number = (dt.Rows[j].Field<int>(i));

                        sum += number;

                        dr[dt.Columns.Count - 1] = Convert.ToInt32(sum);


               Console.WriteLine("Row : {0} , Column : {1} , Value : {2}", i,j, dt.Rows[i][j].ToString());
                        Console.WriteLine(sum);
                    }
                    Console.ReadLine();
                }
            }

更新:12/27/12 * ** * ** * ** * **

所以,我正在尝试的一个解决方案是跳过我知道是文本的行和列。当它尝试过滤每个单元格并将其求和时,我仍然得到“指定的强制转换无效”。还有什么建议吗?

先感谢您。


   DataRow dr = dt.NewRow();

            int sum = 0;
            int number = 0;

            for (int i = 0; i < dt.Columns.Count-1; i++)
            {
                if (dt.Columns[i].ColumnName == "column1")
                {
                    dt.Columns.Cast<DataColumn>().Skip(0);

                }
                if (dt.Columns[i].ColumnName == "column2")
                {
                    dt.Columns.Cast<DataColumn>().Skip(1);
                }
                else
                {

                    for (int j = 0; j < dt.Rows.Count; j++)
                    {
                        dt.Rows.Cast<DataRow>().Skip(0);
                        dt.Rows.Cast<DataRow>().Skip(1);


                        //if (number != -1 && number != 0)
                        //{

                            number = (dt.Rows[j].Field<int>(i));
                            sum += number;
                            dr[dt.Rows.Count] = Convert.ToInt32(sum);
                        //}
                        //else
                        //{
                        //    number = 0;
                        //}


                        Console.WriteLine("Row : {0} , Column : {1} , Value : {2}", i, j, dt.Rows[i][j].ToString());
                        Console.WriteLine(sum);


                    }
                    Console.ReadLine();

                   dataGridView1.DataSource = dt;
                } 


* *更新 12/27 下午 1:30 我已经刮掉了所有以前的代码,并正在尝试测试表和输出。它似乎正在工作,但现在当我将它们添加到最后一行时,我似乎无法将它们总计。我被困在代码的“其他”部分。

    for (int i = 0; i < dt.Columns.Count - 2; i++)
        {

            for (int j = 0; j < dt.Rows.Count - 1; j++)
            {
                string value = dt.Rows[i][j].ToString();
                int num = 0;
                bool res = int.TryParse(value, out num);
                if (res == false)
                {
                    num = 0;
                }
                else
                {
                    int sum = 0;

                    sum += num;
                    DataRow dr;
                   dr["Totals"] = sum;
                   dt.Rows.Add(dr);
                }
            }


            dataGridView1.DataSource = dt;
        }
    }
4

1 回答 1

1

One possibility is that there is a blank value in your data table - you can't cast a null object to an integer, so the Field extension method may be failing.

于 2012-12-26T18:20:43.870 回答