می خواهم توی پروژه خودم در ستونهای DataGrid View تاریخ رو که در دیتابیس به صورت میلادی ذخیره شده به صورت شمسی نمایش بدم. آیا کدهای زیر که نوشتم درسته ؟
System.Globalization.PersianCalendar pcl = new System.Globalization.PersianCalendar();
string shamsi_date = "";
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
int shamsi_year = Convert.ToInt32(pcl.GetYear(ds.Tables[0].Rows[i].Field<DateTime>("birthday")));
int shamsi_month = Convert.ToInt32(pcl.GetMonth(ds.Tables[0].Rows[i].Field<DateTime>("birthday")));
int shamsi_day = Convert.ToInt32(pcl.GetDayOfMonth(ds.Tables[0].Rows[i].Field<DateTime>("birthday")));
shamsi_date = shamsi_year.ToString() + "/" + shamsi_month.ToString() + "/" + shamsi_day.ToString();
ds.Tables[0].Rows[i].SetField<DateTime>("birthday", Convert.ToDateTime(shamsi_date));
}
روشی که شما استفاده کردید به نظر مناسب نیست. شما بهتره یک تابع بنویسید که عملیات تبدیل تاریخ میلادی به شمسی رو انجام بده و در حلقه for فقط از این تابع استفاده کنید. برای این منظور ابتدا یک کلاس ایجاد کنید که عملیات تبدیل تاریخ میلادی به شمسی رو انجام بده.
using MD.PersianDateTime;
using System;
public static class ConvertDateTime
{
public static string ConvertMiladiToShamsi(this DateTime? date, string format)
{
PersianDateTime persianDateTime = new PersianDateTime(date);
return persianDateTime.ToString(format);
}
}
خب حالا فقط کافیه به صورت زیر عمل کنید :
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
shamsi_date = ConvertDateTime.ConvertMiladiToShamsi(YourDate, "yyyy/MM/dd");
}
می بینید که خیلی مرتب تر و خلاصه تر شد.
لینک زیر رو هم مطالعه کنید.
تاریخ :
1404/01/28
- ساعت :
10:46:00 AM
- بازدید :
23
- پاسخ :
1
|
تاریخ :
1404/01/28
- ساعت :
10:27:00 AM
- بازدید :
13
- پاسخ :
1
|
تاریخ :
1399/11/25
- ساعت :
11:22:00 AM
- بازدید :
3954
- پاسخ :
2
|
تاریخ :
1403/12/02
- ساعت :
12:09:00 AM
- بازدید :
310
- پاسخ :
1
|
تاریخ :
1398/07/08
- ساعت :
12:21:00 AM
- بازدید :
3068
- پاسخ :
2
|
تاریخ :
1403/11/23
- ساعت :
08:24:00 PM
- بازدید :
226
- پاسخ :
2
|
تاریخ :
1399/11/10
- ساعت :
10:01:00 PM
- بازدید :
7219
- پاسخ :
4
|
تاریخ :
1399/04/09
- ساعت :
08:51:00 PM
- بازدید :
3124
- پاسخ :
1
|
تاریخ :
1399/03/25
- ساعت :
08:58:00 PM
- بازدید :
3865
- پاسخ :
1
|
تاریخ :
1400/12/18
- ساعت :
10:24:00 AM
- بازدید :
2131
- پاسخ :
1
|
تاریخ :
1404/01/29
- ساعت :
10:55:00 AM
- بازدید :
4
- پاسخ :
0
|
تاریخ :
1404/01/28
- ساعت :
09:29:00 PM
- بازدید :
15
- پاسخ :
0
|
تاریخ :
1404/01/28
- ساعت :
10:46:00 AM
- بازدید :
23
- پاسخ :
1
|
تاریخ :
1404/01/28
- ساعت :
10:27:00 AM
- بازدید :
13
- پاسخ :
1
|
تاریخ :
1404/01/26
- ساعت :
05:27:00 PM
- بازدید :
54
- پاسخ :
1
|
تاریخ :
1404/01/24
- ساعت :
07:09:00 AM
- بازدید :
76
- پاسخ :
0
|
تاریخ :
1404/01/25
- ساعت :
03:09:00 PM
- بازدید :
36
- پاسخ :
1
|
تاریخ :
1404/01/16
- ساعت :
07:20:00 PM
- بازدید :
210
- پاسخ :
1
|
تاریخ :
1404/01/07
- ساعت :
05:02:00 AM
- بازدید :
148
- پاسخ :
1
|
تاریخ :
1402/04/28
- ساعت :
09:04:00 PM
- بازدید :
1339
- پاسخ :
0
|