Page 1 of 1

ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 2:47 pm
by oanirud
สวัสดีครับ
ผมมีวันเปิดเคส กับวันปิดเคสครับ ผมจะเอามาคำนวณว่าผ่านไปกี่วันแล้วครับ
ตามรูปที่แนบมาคือ ผมอยากได้วันที่ เหมือนข้างหน้าอ่ะครับ ผมต้องใช้สูตรยังไงครับ ผมไม่ค่อยเก่งสูตรครับ
15/06/2015 17:05 น.|15/06/2015 17:30 น. = 0/01/1900 0:25 น.(ที่ผมใช่คือเอาข้างหลังลบข้างหน้า)

ขอบคุณครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 3:00 pm
by DhitiBank
oanirud wrote:อ่ะครับ
ในบอร์ดนี้มีกฎห้ามใช้ภาษาแชทนะครับ ตาม Forum rules ด้านบน :aru:

ขอสอบถามเพิ่มนะครับ เวลาลบกันแล้ว คำตอบที่ถูกต้องจะต้องแสดงอย่างไรครับ เพราะมีเพียงเวลาเท่านั้นที่ต่างกัน

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 3:17 pm
by oanirud
ผมอยากได้แบบนี้ครับ
15/06/2015 17:05 น.|15/06/2015 17:30 น. = 15/06/2015 0:25 น. ตามนี้ครับ
ขอบคุณครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 4:14 pm
by DhitiBank
แล้วถ้าต่างวันกันล่ะครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 4:25 pm
by oanirud
อืม...ใช่ๆ ถ้าต่างวันกันก็ให้ขึ้นตามวันที่ close ครับ ต้องทำยังไงครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 4:44 pm
by DhitiBank
เอ่อ ขอโทษทีครับ มีคำถามเพิ่ม
หากว่าอยู่คนละวันกัน แต่เวลาในวัน close น้อยกว่าเวลาวัน open เช่น

Open:15/5/2558 13:00 Close:17/5/2558 9:00

แบบนี้ต้องการให้แสดงอย่างไรครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 5:05 pm
by oanirud
ถ้าเป็นกรณีแบบนี้ ผมอยากให้มันโชว์ว่าเป็นกี่วัน กี่ ชม. Open:15/5/2558 13:00 Close:17/5/2558 9:00 จะได้ เป็น 1วัน20 ชม.

ผมอยากได้ทั้ง 2 แบบคือ
กรณีที่อยู่ในวันเดียวกันกับกรณีที่ข้ามวันไปแล้วครับ ผมค่อยเข้าใจวิธีการคำนวณครับ

ขอบคุณครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Mon Jun 29, 2015 5:44 pm
by DhitiBank
ถ้าอย่างนั้น ลองแบบนี้ครับ

ที่ E2 คีย์

=IF(INT(B2)=INT(C2),TEXT(INT(C2)+MOD(C2,1)-MOD(B2,1),"d/m/yy h:mm"),INT(C2-B2)&TEXT(C2-B2," h:mm"))

Enter ครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Tue Jun 30, 2015 8:54 am
by oanirud
พี่ครับ ผมลองเอาไปรันแล้วได้ผลครับ

ผมอยากรบกวนนิดหนึ่งครับ ช่วยอธิบายสูตรให้หน่อยได้ไหมครับ ผมจะได้เข้าใจมากขึ้น

ขอบคุณล่วงหน้าครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Tue Jun 30, 2015 12:31 pm
by DhitiBank
ได้ครับ ก่อนอื่นต้องเข้าใจก่อนว่าโปรแกรมจะคำนวณวันที่ในรูปแบบจำนวนเต็ม และเวลาในรูปแบบทศนิยมที่น้อยกว่า 1 (1 จะเท่ากับ 1 วันครับ) และจะดูว่าโปรแกรมเห็นเวลาเป็นเท่าไรก็ลองพิมพ์
=((ชม. *60*60)+(นาที*60)+วินาที)/(24*60*60)

จากสูตร

=IF(INT(B2)=INT(C2),TEXT(INT(C2)+MOD(C2,1)-MOD(B2,1),"d/m/yy h:mm"),INT(C2-B2)&TEXT(C2-B2," h:mm"))

มี 4 สูตรย่อยๆ ที่ต้องทำความเข้าใจ
1. INT เป็นสูตรที่จะตัดเอาเฉพาะจำนวนเต็ม (คือจะดูแค่วันที่ ไม่เอาเวลา)

2. MOD เป็นสูตรหาเศษจากการหารครับ เอาวันเวลาหารด้วย 1 (1 คือ 1 วัน) เศษที่เหลือคือเวลาครับ

3. TEXT เป็นสูตรที่เอาไว้ทำให้ตัวเลขมีรูปแบบเป็นข้อความตามต้องการ

4. เงื่อนไขให้ตรวจสอบ

จากสูตรหมายความว่า ถ้าวันใน B2 และ C2 เป็นวันเดียวกัน ให้แสดงค่าจาก

TEXT(INT(C2)+MOD(C2,1)-MOD(B2,1),"d/m/yy h:mm")

คือเอาวันจาก C2 มาบวกกับผลต่างของเวลาระหว่าง C2 กับ B2 แล้วเอา TEXT มาจัดรูปแบบให้ตรงตามต้องการครับ

แต่หาก B2 กับ C2 คนละวันก็ให้แสดง
INT(C2-B2)&TEXT(C2-B2," h:mm")

หมายความว่า แสดงผลต่างของจำนวนวัน (จาก INT) และผลต่างของเวลาที่ไม่เต็มวัน (จาก TEXT) ครับ

Re: ขอถามเรื่องการบวกลบวันที่ครับ

Posted: Tue Jun 30, 2015 5:15 pm
by oanirud
ขอบคุณมากๆครับผม ไม่ได้พี่ผมแย่เลย :D