snasui.com ยินดีต้อนรับ
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ ระบุ Version ของ Excel
ฟอรัมถาม-ตอบปัญหาการใช้งานสูตรและฟังก์ชัน Excel
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] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
navara1112
Member
Posts: 178 Joined: Fri Sep 16, 2016 1:18 pm
#1
Post
by navara1112 » Fri Oct 14, 2016 4:04 pm
สวัสดีครับ
1.1วัน มีจำนวน 24 ช.ม. แต่สร้างเงื่อนไข มี 8:00:00 (8 ชั่วโมง) 1 วันทำงาน
อธิบาย1
N6 ต้องใส่สูตร ต้องบวกจำนวนเวลาจากช่อง E6 10ชม.(เกิน8ชม.) หากบวกแล้วเกินมากกว่า 8 ชั่วโมง ให้มีเงื่อนไขจาก L6 วันที่ 10/10/2016 ให้นับไปอีกวัน หากบวกหลายวันหรือชม. ก็นับต่อไปเรื่อยๆ คำตอบคือ N6 11/10/2016
หากรวมเวลาน้อยกว่า 8 ชม. แล้วให้สูตรตอบ วันเดียวกันกับ L6 =10/10/2016
อธิบาย2
O6 ต้องใส่สูตร ตอบในเวลา 8:00-17:00 เท่านั้น คือรวมเวลาจากช่องตัวอย่าง E6 10 ชม. ในช่อง M6 9:00:00 บวกอีก 10ชม.ใน E6 หากบวกตรงๆจะได้เวลา 19:00:00 ซึ่งไม่ไช่ จะต้องตอบเป็น 11:00:00
ขอบคุณครับ
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 » Fri Oct 14, 2016 4:29 pm
ลองแบบนี้ครับ
N6
=L6+INT(E6/TIME(8,,))
Enter
O6
=M6+MOD(E6,TIME(8,,))
Enter
คัดลอกสูตรทั้งสองลงล่างครับ
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#3
Post
by DhitiBank » Fri Oct 14, 2016 6:10 pm
แก้ไขครับ สูตรเก่าคำนวณไม่ตรงกรณีเศษเวลารวมกันแล้วเกินวัน และไม่ได้ตัดพักเที่ยง
N6
=L6+INT((M6-"8:00"+E6-TIME(--(M6>"12:00"),,))/"8:00")
O6
="8:00"+MOD(M6-"8:00"-TIME(--(M6>"12:00"),,)+MOD(E6,"8:00"),"8:00")+TIME(--(MOD(M6-"8:00"-TIME(--(M6>"12:00"),,)+MOD(E6,"8:00"),"8:00")>"4:00"),,)
navara1112
Member
Posts: 178 Joined: Fri Sep 16, 2016 1:18 pm
#4
Post
by navara1112 » Sat Oct 15, 2016 8:50 am
ครับติดครับ
(o เเละ n สูตรเเรกดีครับ ขอบคุณครับ)
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
#5
Post
by DhitiBank » Sat Oct 15, 2016 10:46 am
สงสัยครับ เพราะ "วันที่เริ่ม" เริ่มจากวันที่ 16/10/2016 ซึ่งเป็นวันหยุด เช่นตัวอย่างแรก ต้องทำงาน 4 ชม. 10 นาที เริ่มจากวันที่ 16/10/2016 เวลา 9.00 น. ต้องไปจบวันไหน เวลาอะไร ช่วยอธิบายวิธีการนับหน่อยได้ไหมครับ
หรือว่ายอมรับงานในวันหยุดได้ แต่ไม่มีการทำงาน จะเริ่มงานในวันใหม่ที่เป็นวันทำงาน หรือเปล่าครับ
navara1112
Member
Posts: 178 Joined: Fri Sep 16, 2016 1:18 pm
#6
Post
by navara1112 » Sat Oct 15, 2016 1:17 pm
N6 โทษครับคือผมยกตัวอย่าง ตรงเริ่มคงไม่ทำวันหยุดเเน่นอน เเต่วันถัดไปหากใช้เวลาทำางานมากขึ้นหรือหลายวัน ใช้เวลาผลิตเป็นสัปดาห์ เป็นเดือน คงมีวันหยุดเเน่นอน ความต้องการอยากให้ข้ามวันหยุด เช่น วันหยุด23-24/10 ให้ข้ามไปที่วันที่25/10เลย
O6 สูตรมีการลบเวลาที่ไม่ต้องการคำนวน เช่นหลังเลิกงานจนถึง 8:00 เเละช่วงพักตั้งเเต 12:00:00-13:00:00 อยากเเก้ไม่ให้หัก 1ชม.ครับ
เพชรพระอุมา
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#7
Post
by DhitiBank » Sat Oct 15, 2016 3:36 pm
ลองปรับสูตรเป็นแบบนี้ครับ
N6
=WORKDAY(L6,INT((M6-"8:00"+F6)/"8:00"),holiday)
O6
="8:00"+MOD(M6-"8:00"+MOD(F6,"8:00"),"8:00")
หากยังไม่ได้คำตอบที่ต้องการ รบกวนทำตัวอย่างมาใหม่ให้คล้ายของจริงครับ คือเริ่มจากวันทำงานจริง พร้อมใส่คำตอบที่ถูกต้องมาเลย ไม่ต้องใส่สูตร ขอสัก 3-4 ตัวอย่างนะครับ
navara1112
Member
Posts: 178 Joined: Fri Sep 16, 2016 1:18 pm
#8
Post
by navara1112 » Sat Oct 15, 2016 10:24 pm
ตามไฟล์นะครับ
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
#9
Post
by DhitiBank » Sun Oct 16, 2016 2:49 pm
ลองปรับสูตรเป็นแบบนี้ครับ
N6
=WORKDAY(L6,INT((M6-$M$4-(M6>1/2)/24+F6)/$M$4),holiday)
O6
=M$4+MOD(M6-M$4-(M6>1/2)/24+MOD(F6,M$4),M$4)+(MOD(M6-M$4-(M6>1/2)/24+MOD(F6,M$4),M$4)>4/24)/24
navara1112
Member
Posts: 178 Joined: Fri Sep 16, 2016 1:18 pm
#10
Post
by navara1112 » Sun Oct 16, 2016 6:32 pm
คุณเก่งมากเลยครับ
ขอบคุณมากครับ จะไปลองใช้ดู
เพชรพระอุมา