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] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
poipoi
Member
Posts: 164 Joined: Fri May 18, 2012 11:23 am
Contact:
#1
Post
by poipoi » Tue Jun 23, 2020 4:48 pm
สวัสดีครับ อาจารย์ทุกท่าน
ผมมีปัญหาเรื่องการรันไฟล์ excel ที่ให้ user ใช้งานครับ
คือตัวไฟล์มันจะมี cell เดียวไว้สำหรับใส่ข้อมูล แล้วให้สูตรทำหน้าที่ของมันไป
แต่ทีนี้ เครื่องผมกับรันได้เร็วอยู่คนเดียวทั้งที่ สเปคไม่ได้ต่างกันเลยกลับรันค้าง 1% ราวเกือบนาทีถึงเด้งไป 3% กว่าจะรันเสร็จก็ราว 3 นาที
กลับกันเครื่องผมไม่เกิน 20วินาทีเสร็จครับ
ผมได้แนบตัวอย่างไฟล์มาให้ลองเล่นดูแล้วครับ
ขอบคุณครับ
You do not have the required permissions to view the files attached to this post.
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#2
Post
by puriwutpokin » Tue Jun 23, 2020 5:36 pm
ควรใช้ช่วงข้อมูลในกรอบที่พอประมาณครับ ไม่ควร ใช้ทั้ง คอลัมน์ สูตรจะทำงานทุกบรรทัดในบางฟังก์ชั่น และบางฟังก์ชั่นก็จะ หน่วงมากถ้าใช้ทั้งคอลัมน์ เช่น Sumproduct ครับ ลองปรับเป็นช่วงดูครับ
poipoi
Member
Posts: 164 Joined: Fri May 18, 2012 11:23 am
Contact:
#3
Post
by poipoi » Tue Jun 23, 2020 8:55 pm
ขอบคุณครับ แต่พอใส่ช่องงข้อมูลลงไป มันกลับไปจับอะไรก็ไม่รู้ออกมาโชว์ครับ
=IFERROR(INDEX(Combine!$B2:$B64190,AGGREGATE(15,6,ROW(Combine!$B2:$B64190)/ISNA(MATCH(Combine!$B2:$B64190,Raw!$B2:$B3589,))/ISNUMBER(FIND($A$3,Combine!$B2:$B64190)),ROWS(C$3:C3))),"")
ขอบคุณครับ
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#4
Post
by puriwutpokin » Tue Jun 23, 2020 9:00 pm
ปรับเป็น
=IFERROR(INDEX(Combine!$B:$B,AGGREGATE(15,6,ROW(Combine!$B2:$B64190)/ISNA(MATCH(Combine!$B2:$B64190,Raw!$B2:$B3589,))/ISNUMBER(FIND($A$3,Combine!$B2:$B64190)),ROWS(C$3:C3))),"")
poipoi
Member
Posts: 164 Joined: Fri May 18, 2012 11:23 am
Contact:
#5
Post
by poipoi » Tue Jun 23, 2020 9:07 pm
ได้แล้วครับ สอบถามครับ ทำไมหน้า AGGREGATE ถึงไม่ระบุช่วงครับ
poipoi
Member
Posts: 164 Joined: Fri May 18, 2012 11:23 am
Contact:
#6
Post
by poipoi » Tue Jun 23, 2020 9:28 pm
ลองให้เครื่องใช้แล้วนะครับ ก็ยังเหมือนเดิม แทบไม่โหลดเลย แต่เครื่องผมกลับโหลดไวมาก
snasui
Site Admin
Posts: 31255 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#7
Post
by snasui » Tue Jun 23, 2020 9:47 pm
puriwutpokin wrote: Tue Jun 23, 2020 5:36 pm
ควรใช้ช่วงข้อมูลในกรอบที่พอประมาณครับ ไม่ควร ใช้ทั้ง คอลัมน์ สูตรจะทำงานทุกบรรทัดในบางฟังก์ชั่น และบางฟังก์ชั่นก็จะ หน่วงมากถ้าใช้ทั้งคอลัมน์ เช่น Sumproduct ครับ ลองปรับเป็นช่วงดูครับ
แก้ไขสูตรที่อ้างอิงทั้งคอลัมน์ให้เหลือเท่าที่ข้อมูลจะขยายไปถึงครับ
poipoi
Member
Posts: 164 Joined: Fri May 18, 2012 11:23 am
Contact:
#8
Post
by poipoi » Wed Jun 24, 2020 2:51 pm
ลองปรับเป็นเฉพาะช่วงข้อมูลแล้วครับ รันเองแค่กระพริบตาก็เสร็จ แต่เครื่องอื่น 3-4 นาทีเลยครับ
snasui
Site Admin
Posts: 31255 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#9
Post
by snasui » Wed Jun 24, 2020 6:16 pm
ลองแนบไฟล์หลังปรับสูตรมาอีกรอบจะได้ช่วยตรวจสอบอีกครั้งครับ
snasui
Site Admin
Posts: 31255 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#11
Post
by snasui » Wed Jun 24, 2020 8:39 pm
เนื่องจากข้อมูลที่ใช้ในการ Match ด้วยสูตรมีจำนวนมากจึงทำให้เกิดการคำนวณช้าครับ
สำหรับสูตรในไฟล์ล่าสุดยังมีการเลือกทั้งคอลัมน์ในฟังก์ชั่น Vlookup ควรปรับช่วงข้อมูลให้เหลือเฉพาะเท่าที่จำเป็น เช่น
=IFERROR(VLOOKUP($C3,Combine!B$2:C$64190,2,0),"") เป็นต้น ซึ่งในกรณีนี้แม้จะปรับช่วงข้อมูลให้เหมาะสมแล้วก็ไม่ได้ช่วยให้เร็วขึ้นเกิดจากสาเหตุที่กล่าวแล้วข้างต้นครับ