显示foreach循环的每个结果

时间:2012-11-15 21:28:03

标签: c# datetime datagridview foreach

我创建了一个名为GetDataRange的<List>DateTime类,以便用户可以在两个特定日期之间获得天数。

然后我想在数据网格视图的列中显示日期。我使用foreach循环,这个循环会导致问题。问题是它不会显示列中的所有日期,因为我想在其他日历中显示所有日期。看代码:

for (int i = 0; i < dtEnd.Subtract(dtStart).Days; i++)
        {
            TimeSpan counter = new TimeSpan(i, 0, 0, 0);

            string s1 = "10/9/2012";
            string s2 = "11/10/2012";
            d1 = Convert.ToDateTime(s1);
            d2 = Convert.ToDateTime(s2);

            foreach (DateTime item in GetDateRange(d1, d2))
            {
                s = item.ToShortDateString();
            }


            PersianCalendar p = new PersianCalendar();
            DateTime date = Convert.ToDateTime(s);
            int day = p.GetDayOfMonth(date);
            int month = p.GetMonth(date);
            int year = p.GetYear(date);
            string dt = string.Format("{0}/{1}/{2}", year, month, day);
            dataGridView1.Columns.Add(string.Format("col{0}", i), string.Format("{0} {1}", (dtStart + counter).DayOfWeek.ToString(), dt));


        }

由于foreach循环,它只会显示一天。 DayOfWeek工作正常,但问题是显示foreach循环中的日子,它只会显示一天。

更新

字符串dt仅显示一天它不会显示其他日期。

1 个答案:

答案 0 :(得分:0)

你做不到。因为每次在循环中你都会覆盖这个值。你能在新的一行显示日期吗?

试试这个:

for (int i = 0; i < dtEnd.Subtract(dtStart).Days; i++)
        {
            TimeSpan counter = new TimeSpan(i, 0, 0, 0);                                       
           dataGridView1.Columns.Add(string.Format("col{0}", i), string.Format("{0}", (dtStart + counter).DayOfWeek.ToString()));
        }

然后为此添加新行:

 d1 = dtStart;
        d2 = dtEnd;
        foreach (DateTime item in GetDateRange(d1, d2))
        {
            int day = p.GetDayOfMonth(item);
            int month = p.GetMonth(item);
            int year = p.GetYear(item);
            string dt1 = string.Format("{0}/{1}/{2}", year, month, day);
            listBox1.Items.Add(dt1);

        }
        dataGridView1.Rows.Add();
        for (int i = 0; i < dataGridView1.Columns.Count; i++)
        {
            try
            {
                dataGridView1.Rows[0].Cells[i].Value = listBox1.Items[i];
            }
            catch (Exception)
            {

            }

        }
相关问题