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]
เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
gfnop
Member
Posts: 4 Joined: Thu Apr 08, 2010 10:06 am
#1
Post
by gfnop » Thu Apr 08, 2010 10:31 am
คือมีไฟล์ข้อมูลการขายอยู่ค่ะ ในไฟล์มี sheet ย่อย เป็นหน้า input ข้อมูลดิบ (sheet1), หน้าเรียงข้อมูลที่ต้องการ (sheet2), หน้าค้นหาข้อมูล (sheet3)
ใน sheet1 จะ input ข้อมูลเรียงเป็นวันที่--ยอดเงิน เช่น
1/1/2010--100
2/1/2010--200
เรียงลงไปเรื่อยๆ ทีนี้พอข้อมูลมันเยอะขึ้น ตอนค้นหาข้อมูล ก็จะเริ่มหายาก เพราะต้องการให้ข้อมูลล่าสุดให้ขึ้นมาก่อน
เลยสงสัยว่าจะทำไงให้มัน auto sort ข้อมูลจากวันที่ล่าสุดที่ input ใน sheet1 ไปไว้ใน sheet2
เวลาค้นหา (ดึงข้อมูลจาก sheet2) มันจะได้เรียงจากวันที่ล่าสุดอ่ะค่ะ
ช่วยแนะนำด้วยค่ะ
snasui
Site Admin
Posts: 30917 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:
#2
Post
by snasui » Thu Apr 08, 2010 11:24 am
สวัสดีครับ
ลองแนบไฟล์ตัวอย่างมาให้ดูหน่อยและอธิบายเพิ่มเติมถึงเงื่อนไขในการค้นหาด้วยครับ
สำหรับการค้นหาในบางลักษณะไม่จำเป็นต้องจัดเรียงข้อมูลก่อนครับ สามารถค้นหาได้ด้วยสูตรหรือด้วย Filter หรือ Advanced Filter หรือใช้ VBA ช่วยในการค้นหาก็ได้
gfnop
Member
Posts: 4 Joined: Thu Apr 08, 2010 10:06 am
#3
Post
by gfnop » Thu Apr 08, 2010 12:30 pm
เวลาค้นหาข้อมูลต้องการให้เรียงจากวันที่ล่าสุดไปแรกสุดค่ะ เพราะเมื่อข้อมูลเยอะขึ้นมันจะเกินหน้าจอและค้นหายากน่ะค่ะ ไม่รู้ต้องเขียนสูตรเพิ่มเติมยังไงบ้าง ช่วยแนะนำด้วยค่ะ (อยากให้แสดงผลในหน้าจอนี้เลยน่ะค่ะ ไม่ต้องใช้ filter เพราะ user ที่เป็นคนใช้งาน ค่อนข้าง low tech น่ะค่ะ ให้ key ข้อมูลกับดูข้อมูลอย่างเดียว เพราะเค้าใช้ excel ได้ตามที่สั่ง ถ้าซับซ้อนมากขึ้นก็ทำไม่ได้+ทำผิดแล้ว เลยอยากให้ใช้ง่ายๆน่ะค่ะ)
You do not have the required permissions to view the files attached to this post.
snasui
Site Admin
Posts: 30917 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:
#4
Post
by snasui » Thu Apr 08, 2010 1:23 pm
สามารถประยุกต์จากสูตรเดิมได้เลยครับ
ตัวอย่างเช่นที่ A5 คีย์
=IF(ROWS(A$2:A2)<=$F$2,LOOKUP($F$2-ROWS(A$2:$A2)+1,Buffer!$G:$G,Buffer!E:E),"")
Enter > Copy ลงด้านล่าง
ดูไฟล์แนบประกอบครับ
You do not have the required permissions to view the files attached to this post.
gfnop
Member
Posts: 4 Joined: Thu Apr 08, 2010 10:06 am
#5
Post
by gfnop » Thu Apr 08, 2010 6:08 pm
ทำได้แล้ว ขอบคุณมากๆค่ะ