snasui.com ยินดีต้อนรับ
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ ระบุ Version ของ Excel
ฟอรัมถาม-ตอบปัญหาการใช้งาน MS Excel and VBA
Forum rules
ไม่อนุญาตให้ใช้ภาษาแชทในการถามและตอบปัญหา ไม่ใช้คำว่า "คับ" หรือ "อ่ะครับ" แทนคำว่า "ครับ" ไม่ใช้คำว่า "เด๋ว" แทนคำว่า "เดี๋ยว" เป็นต้น เนื่องจากเมื่อแปลเป็นภาษาต่างประเทศแล้วจะให้ความหมายผิดไปจากที่ควรจะเป็น
ห้ามถามโดยระบุชื่อผู้ตอบและต้องตั้งชื่อกระทู้ให้สื่อถึงปัญหาที่จะถาม ไม่ตั้งชื่อว่า ช่วยด้วยครับ, มีปัญหามาปรึกษาครับ เป็นต้น
กรุณาอธิบายปัญหาและระบุคำตอบที่ต้องการมาในกระทู้ด้วยเสมอถึงแม้จะอธิบายไว้ในไฟล์แนบแล้วก็ตาม ทั้งนี้เพื่ออำนวยความสะดวกแก่เพื่อนสมาชิกในการค้นหาข้อมูล
กรุณาแนบไฟล์ตัวอย่างพร้อมแสดงคำตอบที่ถูกต้องมาในไฟล์ด้วยเพื่อให้ง่ายต่อการทำความเข้าใจและสะดวกต่อการตอบคำถาม (ขนาดไฟล์ไม่เกิน 500Kb ขนาดภาพไม่เกิน 800*600 Pixel) ไม่แนบเป็น Link มาจากแหล่งอื่นที่อาจจะถูกลบทิ้งไปโดยต้นทางในภายหลัง นอกจากนี้ไม่ควรแนบไฟล์ที่มีข้อมูลสำคัญอันก่อให้เกิดความเสียหายกับตนเองและผู้อื่น
กรณีเป็นคำถามเกี่ยวกับ Programming เช่น VBA, VB.Net, C#, SQL ฯลฯ ต้องลองเขียนมาเองก่อนเสมอ ถามเฉพาะที่ติดปัญหา ระบุ Module, Procedure ที่ติดปัญหาให้ชัดเจน กรุณาโพสต์ Code ให้แสดงเป็น Code คือเปิดด้วย [code]
และปิดด้วย [/code]
ตัวอย่างเช่น [code]dim r as range[/code]
เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
oanirud
Member
Posts: 56 Joined: Wed Nov 05, 2014 11:34 am
#1
Post
by oanirud » Mon Jun 29, 2015 2:47 pm
สวัสดีครับ
ผมมีวันเปิดเคส กับวันปิดเคสครับ ผมจะเอามาคำนวณว่าผ่านไปกี่วันแล้วครับ
ตามรูปที่แนบมาคือ ผมอยากได้วันที่ เหมือนข้างหน้าอ่ะครับ ผมต้องใช้สูตรยังไงครับ ผมไม่ค่อยเก่งสูตรครับ
15/06/2015 17:05 น.|15/06/2015 17:30 น. = 0/01/1900 0:25 น.(ที่ผมใช่คือเอาข้างหลังลบข้างหน้า)
ขอบคุณครับ
You do not have the required permissions to view the files attached to this post.
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#2
Post
by DhitiBank » Mon Jun 29, 2015 3:00 pm
oanirud wrote: อ่ะ ครับ
ในบอร์ดนี้มีกฎห้ามใช้ภาษาแชทนะครับ ตาม Forum rules ด้านบน
ขอสอบถามเพิ่มนะครับ เวลาลบกันแล้ว คำตอบที่ถูกต้องจะต้องแสดงอย่างไรครับ เพราะมีเพียงเวลาเท่านั้นที่ต่างกัน
oanirud
Member
Posts: 56 Joined: Wed Nov 05, 2014 11:34 am
#3
Post
by oanirud » Mon Jun 29, 2015 3:17 pm
ผมอยากได้แบบนี้ครับ
15/06/2015 17:05 น.|15/06/2015 17:30 น. = 15/06/2015 0:25 น. ตามนี้ครับ
ขอบคุณครับ
oanirud
Member
Posts: 56 Joined: Wed Nov 05, 2014 11:34 am
#5
Post
by oanirud » Mon Jun 29, 2015 4:25 pm
อืม...ใช่ๆ ถ้าต่างวันกันก็ให้ขึ้นตามวันที่ close ครับ ต้องทำยังไงครับ
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#6
Post
by DhitiBank » Mon Jun 29, 2015 4:44 pm
เอ่อ ขอโทษทีครับ มีคำถามเพิ่ม
หากว่าอยู่คนละวันกัน แต่เวลาในวัน close น้อยกว่าเวลาวัน open เช่น
Open:15/5/2558 13:00 Close:17/5/2558 9:00
แบบนี้ต้องการให้แสดงอย่างไรครับ
oanirud
Member
Posts: 56 Joined: Wed Nov 05, 2014 11:34 am
#7
Post
by oanirud » Mon Jun 29, 2015 5:05 pm
ถ้าเป็นกรณีแบบนี้ ผมอยากให้มันโชว์ว่าเป็นกี่วัน กี่ ชม. Open:15/5/2558 13:00 Close:17/5/2558 9:00 จะได้ เป็น 1วัน20 ชม.
ผมอยากได้ทั้ง 2 แบบคือ
กรณีที่อยู่ในวันเดียวกันกับกรณีที่ข้ามวันไปแล้วครับ ผมค่อยเข้าใจวิธีการคำนวณครับ
ขอบคุณครับ
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#8
Post
by DhitiBank » Mon Jun 29, 2015 5:44 pm
ถ้าอย่างนั้น ลองแบบนี้ครับ
ที่ 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 ครับ
oanirud
Member
Posts: 56 Joined: Wed Nov 05, 2014 11:34 am
#9
Post
by oanirud » Tue Jun 30, 2015 8:54 am
พี่ครับ ผมลองเอาไปรันแล้วได้ผลครับ
ผมอยากรบกวนนิดหนึ่งครับ ช่วยอธิบายสูตรให้หน่อยได้ไหมครับ ผมจะได้เข้าใจมากขึ้น
ขอบคุณล่วงหน้าครับ
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#10
Post
by DhitiBank » Tue Jun 30, 2015 12:31 pm
ได้ครับ ก่อนอื่นต้องเข้าใจก่อนว่าโปรแกรมจะคำนวณวันที่ในรูปแบบจำนวนเต็ม และเวลาในรูปแบบทศนิยมที่น้อยกว่า 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) ครับ
oanirud
Member
Posts: 56 Joined: Wed Nov 05, 2014 11:34 am
#11
Post
by oanirud » Tue Jun 30, 2015 5:15 pm
ขอบคุณมากๆครับผม ไม่ได้พี่ผมแย่เลย