Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > .NET Framework > Forum > การคำนวณอายุที่เราเลือกวันเกิดจาก DateTimePicker ให้แสดงออกมาทาง textbox ว่า อายุ กีปี กีเดือน กี่วัน



 

การคำนวณอายุที่เราเลือกวันเกิดจาก DateTimePicker ให้แสดงออกมาทาง textbox ว่า อายุ กีปี กีเดือน กี่วัน

 



Topic : 071379

Guest




การคำนวณอายุที่เราเลือกวันเกิดจาก DateTimePicker ให้แสดงออกมาทาง textbox ว่า อายุ กีปี กีเดือน กี่วัน ต้องเขียน Code ยังไงเหรอ งงมาก



Tag : .NET, VB.NET







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2012-01-05 23:20:39 By : TTcom View : 9720 Reply : 9
 

 

No. 1



โพสกระทู้ ( 154 )
บทความ ( 0 )



สถานะออฟไลน์


Code ที่แสดงให้นี้อาจมี Error ถ้ากำหนดวันที่เป็นอนาคตนะครับ ต้องไปกำหนด MaximumDate เป็น Date.Today ที่ตัว DateTimePicker ก่อนนะครับ

Code (VB.NET)
Public Class Form1
    Private Sub DateTimePicker1_ValueChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles DateTimePicker1.ValueChanged
        Dim birthDayThisYear As New Date(Date.Today.Year, Me.DateTimePicker1.Value.Month, Me.DateTimePicker1.Value.Day)
        Dim years = Date.Today.Year - Me.DateTimePicker1.Value.Year
        Dim months = Date.Today.Month - Me.DateTimePicker1.Value.Month
        Dim days = Date.Today.Day - Me.DateTimePicker1.Value.Day

        If birthDayThisYear > Date.Today Then
            years -= 1
            months += 12
        End If

        If birthDayThisYear.Day > Date.Today.Day Then
            Dim dt As New Date(birthDayThisYear.Year, DateTime.Today.Month - 1, birthDayThisYear.Day)
            Dim ts As TimeSpan = Date.Today - dt

            months -= 1
            days = ts.Days
        End If

        Me.TextBox1.Text = String.Format("อายุ {0} ปี {1} เดือน {2} วัน", years.ToString, months.ToString, days.ToString)
    End Sub
End Class







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 00:06:34 By : gunnermontana
 


 

No. 2

Guest


มันเลือกแล้ว Error ที่
Dim dt As New Date(birthDayThisYear.Year, DateTime.Today.Month - 1, birthDayThisYear.Day)


Error ----> Year, Month, and Day parameters describe an un-representable DateTime.
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 09:25:56 By : TTcom
 

 

No. 3

Guest


Code (VB.NET)
Private Sub DateTimePicker1_ValueChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles DateTimePicker1.ValueChanged
       
     

        Dim y1 As New DateTime
        Dim y2 As New DateTime
        y2 = DateTime.Now.ToString("dd/MM/yyyy")
        y1 = DateTimePicker1.Value.ToString("dd/MM/yyyy")
        Dim year As Integer = DateDiff(DateInterval.Year, CDate(y1), CDate(y2))

        TextBox1.Text = year
        Exit Sub
End Sub

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 11:20:52 By : noh
 


 

No. 4

Guest


Code (C#)
public class DateDifference
        {
            private DateTime _FromDate;
            private DateTime _ToDate;
            private int _Year = 0;
            private int _Month = 0;
            private int _Day = 0;

            public int Year
            {
                get { return _Year; }
                set { _Year = value; }
            }
            public int Month
            {
                get { return _Month; }
                set { _Month = value; }
            }
            public int Day
            {
                get { return _Day; }
                set { _Day = value; }
            }
            public DateTime FromDate
            {
                get { return _FromDate; }
                set { _FromDate = value; }
            }
            public DateTime ToDate
            {
                get { return _ToDate; }
                set { _ToDate = value; }
            }

            /// <summary>
            /// defining Number of days in month; index 0=> january and 11=> December
            /// february contain either 28 or 29 days, that's why here value is -1
            /// which wil be calculate later.
            /// </summary>
            private int[] monthDay = new int[12] { 31, -1, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
            
            public DateDifference(DateTime argFromDate)
            {
                _ToDate = DateTime.Now;
                _FromDate = argFromDate;
                CalcDifferenceDate();
            }

            public DateDifference(DateTime argFromDate, DateTime argToDate)
            {
                _ToDate = argToDate;
                _FromDate = argFromDate;
                CalcDifferenceDate();
            }

            private void SwapDate(ref DateTime LeftDate, ref DateTime RightDate)
            {
                DateTime tempDate;
                if (LeftDate > RightDate)
                {
                    tempDate = LeftDate;
                    LeftDate = RightDate;
                    RightDate = tempDate;
                }
                else
                {
                    LeftDate = LeftDate;
                    RightDate = RightDate;
                }
            }

            private void CalcDifferenceDate()
            {

                SwapDate(ref _FromDate, ref _ToDate);
                int carryFlag = 0;

                // ***************************
                // Day calculation 
                if (this.FromDate.Day > this.ToDate.Day)
                    carryFlag = this.monthDay[this.FromDate.Month - 1];

                // febuary detect
                if (carryFlag == -1)
                {
                    if (CheckedLeapYear(this.FromDate))
                        // leap year february contain 29 days
                        carryFlag = 29;
                    else
                        carryFlag = 28;
                }

                if (carryFlag != 0)
                {
                    this.Day = (this.ToDate.Day + carryFlag) - this.FromDate.Day;
                    carryFlag = 1;
                }
                else
                    this.Day = this.ToDate.Day - this.FromDate.Day;

                // ***************************
                // Month calculation 

                if ((this.FromDate.Month + carryFlag) > this.ToDate.Month)
                {
                    this.Month = (this.ToDate.Month + 12) - (this.FromDate.Month + carryFlag);
                    carryFlag = 1;
                }
                else
                {
                    this.Month = this.ToDate.Month - (this.FromDate.Month + carryFlag);
                    carryFlag = 0;
                }

                this.Year = this.ToDate.Year - (this.FromDate.Year + carryFlag);
            }

            private bool CheckedLeapYear(DateTime checkedDate)
            {
                int myYear = checkedDate.Year;
                return (((myYear % 4) == 0) && ((myYear % 100) != 0) || ((myYear % 400) == 0));
            }

            public string ToString(string argYearUnit, string argMonthUnit, string argDayUnit)
            {
                string retStr = string.Empty;
                if (this.Year > 0)
                    retStr = retStr + string.Format("{0} {1} ", this.Year.ToString("#,##0"), argYearUnit);
                if (this.Month > 0)
                    retStr = retStr + string.Format("{0} {1} ", this.Month.ToString("#,##0"), argMonthUnit);
                if (this.Day > 0)
                    retStr = retStr + string.Format("{0} {1} ", this.Day.ToString("#,##0"), argDayUnit);
                return retStr.Trim();
            }

            public override string ToString()
            {
                return this.ToString("ปี", "เดือน", "วัน");
            }
        }



DateDifference d = new DateDifference(Convert.ToDateTime(lbstart.Text), DateTime.Now);///ตอนเรียกใช้
                lbtotaldate.Text = d.ToString();


อันนี้ได้ปะ ผมเอาไว้ใช้คำนวณเวลา ของพนักงาน ว่าคนนี้ทำมากี่ เดือน กี่วัน กี่ปีแล้ว โค้ดผมได้มาจากเวปนี้แหละ ลองเล่นดูครับ
ผมเอาโค้ดนี้มาตอนแรก นั่งงงแทบตาย ไล่ดูดีๆ จะเข้าใจเองครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 11:31:23 By : patzy
 


 

No. 5

Guest


Try it .

Code (VB.NET)
Private Sub DateTimePicker1_ValueChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles DateTimePicker1.ValueChanged
       
     

        Dim y1 As New DateTime
        Dim y2 As New DateTime
        y2 = DateTime.Now.ToString("MM/dd/yyyy")
        y1 = DateTimePicker1.Value.ToString("MM/dd/yyyy")
        Dim year As Integer = DateDiff(DateInterval.Year, CDate(y1), CDate(y2))
        Dim Month As Integer = DateDiff(DateInterval.Month, CDate(y1), CDate(y2))
        Dim Day As Integer = DateDiff(DateInterval.Day, CDate(y1), CDate(y2))
        TextBox1.Text = year & ":" & Month & ":" & Day
        Exit Sub
End Sub

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 11:41:51 By : noh
 


 

No. 6

Guest


คุณ : patzy มันเป็น C# ป่าว

ส่วนของคุณ noh

Conversion from string "01/13/2555" to type 'Date' is not valid. รูปแบบวันที่น่าจะไม่เหมือนกัน


ตอนนี้ผมใช้ มันแสดงแค่ปี ออกมา ไม่มีเดือน วัน ต้องทำไง
TxtAge.Text = DateDiff(DateInterval.Year, DTP1.Value, Now)

อยากได้ที่เป็นแบบ อายุ 21 ปี 9 เดือน 5 วัน ประมาณนี้ ไม่ใช้เดือนหรือวันทั้งหมด
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 13:13:57 By : TTcom
 


 

No. 7



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

แปลงเป็น VB.NET ให้ครับ

Code (VB.NET)
Public Class DateDifference
	Private _FromDate As DateTime
	Private _ToDate As DateTime
	Private _Year As Integer = 0
	Private _Month As Integer = 0
	Private _Day As Integer = 0

	Public Property Year() As Integer
		Get
			Return _Year
		End Get
		Set
			_Year = value
		End Set
	End Property
	Public Property Month() As Integer
		Get
			Return _Month
		End Get
		Set
			_Month = value
		End Set
	End Property
	Public Property Day() As Integer
		Get
			Return _Day
		End Get
		Set
			_Day = value
		End Set
	End Property
	Public Property FromDate() As DateTime
		Get
			Return _FromDate
		End Get
		Set
			_FromDate = value
		End Set
	End Property
	Public Property ToDate() As DateTime
		Get
			Return _ToDate
		End Get
		Set
			_ToDate = value
		End Set
	End Property

	''' <summary>
	''' defining Number of days in month; index 0=> january and 11=> December
	''' february contain either 28 or 29 days, that's why here value is -1
	''' which wil be calculate later.
	''' </summary>
	Private monthDay As Integer() = New Integer(11) {31, -1, 31, 30, 31, 30, _
		31, 31, 30, 31, 30, 31}

	Public Sub New(argFromDate As DateTime)
		_ToDate = DateTime.Now
		_FromDate = argFromDate
		CalcDifferenceDate()
	End Sub

	Public Sub New(argFromDate As DateTime, argToDate As DateTime)
		_ToDate = argToDate
		_FromDate = argFromDate
		CalcDifferenceDate()
	End Sub

	Private Sub SwapDate(ByRef LeftDate As DateTime, ByRef RightDate As DateTime)
		Dim tempDate As DateTime
		If LeftDate > RightDate Then
			tempDate = LeftDate
			LeftDate = RightDate
			RightDate = tempDate
		Else
			LeftDate = LeftDate
			RightDate = RightDate
		End If
	End Sub

	Private Sub CalcDifferenceDate()

		SwapDate(_FromDate, _ToDate)
		Dim carryFlag As Integer = 0

		' ***************************
		' Day calculation 
		If Me.FromDate.Day > Me.ToDate.Day Then
			carryFlag = Me.monthDay(Me.FromDate.Month - 1)
		End If

		' febuary detect
		If carryFlag = -1 Then
			If CheckedLeapYear(Me.FromDate) Then
				' leap year february contain 29 days
				carryFlag = 29
			Else
				carryFlag = 28
			End If
		End If

		If carryFlag <> 0 Then
			Me.Day = (Me.ToDate.Day + carryFlag) - Me.FromDate.Day
			carryFlag = 1
		Else
			Me.Day = Me.ToDate.Day - Me.FromDate.Day
		End If

		' ***************************
		' Month calculation 

		If (Me.FromDate.Month + carryFlag) > Me.ToDate.Month Then
			Me.Month = (Me.ToDate.Month + 12) - (Me.FromDate.Month + carryFlag)
			carryFlag = 1
		Else
			Me.Month = Me.ToDate.Month - (Me.FromDate.Month + carryFlag)
			carryFlag = 0
		End If

		Me.Year = Me.ToDate.Year - (Me.FromDate.Year + carryFlag)
	End Sub

	Private Function CheckedLeapYear(checkedDate As DateTime) As Boolean
		Dim myYear As Integer = checkedDate.Year
		Return (((myYear Mod 4) = 0) AndAlso ((myYear Mod 100) <> 0) OrElse ((myYear Mod 400) = 0))
	End Function

	Public Overloads Function ToString(argYearUnit As String, argMonthUnit As String, argDayUnit As String) As String
		Dim retStr As String = String.Empty
		If Me.Year > 0 Then
			retStr = retStr & String.Format("{0} {1} ", Me.Year.ToString("#,##0"), argYearUnit)
		End If
		If Me.Month > 0 Then
			retStr = retStr & String.Format("{0} {1} ", Me.Month.ToString("#,##0"), argMonthUnit)
		End If
		If Me.Day > 0 Then
			retStr = retStr & String.Format("{0} {1} ", Me.Day.ToString("#,##0"), argDayUnit)
		End If
		Return retStr.Trim()
	End Function

	Public Overrides Function ToString() As String
		Return Me.ToString("ปี", "เดือน", "วัน")
	End Function
End Class

Dim d As New DateDifference(Convert.ToDateTime(lbstart.Text), DateTime.Now)
lbtotaldate.Text = d.ToString()

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 13:25:19 By : webmaster
 


 

No. 8



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

Quote:
Conversion from string "01/13/2555" to type 'Date' is not valid.


ลองทำการ Set CultureInfo("en-US")
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 13:27:52 By : webmaster
 


 

No. 9

Guest


ขอบคุณคับ เดี่ยวลองไล่ดู
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-01-06 13:31:44 By : TTcom
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : การคำนวณอายุที่เราเลือกวันเกิดจาก DateTimePicker ให้แสดงออกมาทาง textbox ว่า อายุ กีปี กีเดือน กี่วัน
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 05
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่