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]
เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#1
Post
by lnongkungl » Sat Aug 04, 2018 2:08 pm
รบกวนสอบถามอาจารย์ หรือผู้รู้ครับ คือรับข้อมูลจากเครื่องยิงบาร์โค๊ดแล้วต้องการให้ curcer อยู่ที่เดิมครับ นอกจากเข้าไปตั้งค่า ใน Advance Option > After pressing Enter,move selection แล้วมีวิธีไหนอีกบ้างครับ เพราะว่าตั้งค่าตรงนี้แล้วมันเป็นทั้งหมด คือต้องการให้เป็นแค่ ไฟล์นี้ หรือ sheet นี้ แค่ที่เดียวครับ เพราะการรับค่าจากเครื่องยิงบาร์โค๊ดแล้วมัน enter ให้ auto ครับ
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#2
Post
by snasui » Sat Aug 04, 2018 2:22 pm
หากไม่กำหนดผ่าน Option ก็ต้องเขียน VBA เข้าไปช่วย ซึ่งต้องเขียนมาเองก่อน ติดตรงไหนค่อยถามกันต่อครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#3
Post
by lnongkungl » Mon Aug 06, 2018 9:32 am
ผมเขียนไว้แล้วครับ แต่มันไม่เป็นผล คือ ถ้าคีย์เลขบาร์โค๊ดเอาเอง แล้วกด Enter มันก็ไม่เลื่อนลงมาครับ แต่พอใช้เครื่องยิงบาร์โค๊ดยิงแล้วมันก็ลงมาตลอดเลย
โค๊ดที่ผมใส่ ปิดท้าย Module ครับ
Code: Select all
Range("ForminputID").ClearContents
Range("ForminputID").Select
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#4
Post
by snasui » Mon Aug 06, 2018 8:15 pm
เขียน Code ไว้ใน Change Event ครับ
ลองศึกษาจากกระทู้เหล่านี้ครับ
Change Event
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#5
Post
by lnongkungl » Tue Aug 07, 2018 11:45 am
ลองเอาโค๊ดไปปิดท้ายที่ Change Event แล้วครับ ก็เหมือนเดิม คือคีย์มือแล้ว enter ผลคือ cursor อยู่ที่เดิม แต่ถ้ายิงด้วยตัวยิงบาร์โค๊ดแล้ว cursor ก็ยังเลื่อนลงมาอยู่ดี
หรือที่ตัวยิงบาร์โค๊ดไม่ใช่ enter แต่ผมก็จบด้วย .select ใน range ที่ต้องการไว้แล้ว แต่ทำไมยังไม่ได้
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#6
Post
by snasui » Tue Aug 07, 2018 7:13 pm
ลองแนบไฟล์ที่เขียน Code แล้วมาดูกันครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#7
Post
by lnongkungl » Wed Aug 08, 2018 10:49 am
ไฟล์แนบครับ อาจารย์
You do not have the required permissions to view the files attached to this post.
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#8
Post
by snasui » Wed Aug 08, 2018 7:25 pm
เพิ่ม
Target.Activate
เข้าไปก่อน
End Sub
เพื่อให้เลือกเซลล์ที่เปลี่ยนแปลง แล้วลองยิง Barcode ดูใหม่ครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#9
Post
by lnongkungl » Thu Aug 09, 2018 3:14 pm
ครับ เด๋วลองดู แล้วจะมาแจ้งผล ครับ
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#10
Post
by snasui » Thu Aug 09, 2018 10:48 pm
lnongkungl wrote: Thu Aug 09, 2018 3:14 pm
ครับ
เด๋ว ลองดู แล้วจะมาแจ้งผล ครับ
คำที่ผมระบายสีผิดกฎการใช้บอร์ดข้อ 1 ด้านบน กรุณาระมัดระวังด้วยครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#11
Post
by lnongkungl » Sat Aug 11, 2018 1:59 pm
ขออภัยครับ รีบพิมพ์ไปหน่อย
ลองแล้วครับ เป็นเหมือนเดิม หรือจะเป็นที่ตัวที่ใช้ยิงบาร์โค๊ด มันไม่ใช่ code enter
แล้วมันจะเป็นอะไร เพราะคีย์มือแล้ว enter cursor ไม่เลื่อนครับ
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#12
Post
by snasui » Sat Aug 11, 2018 2:16 pm
หากเป็นเช่นนั้นคงต้องลองดักจับโดยแทรกทุก Event ของ Worksheet แล้วสังเกตว่า Event ไหนทำงานบ้าง จากนั้นค่อยไปเขียน Code ให้เลื่อน Cursor กลับไปไว้ตำแหน่งเดิมหรือตำแหน่งที่ต้องการครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#13
Post
by lnongkungl » Sat Aug 11, 2018 2:28 pm
ก็มี Even Change อันเดียวครับ ใน worksheet แล้วก็ดึง module มาใช้ในการ add item แต่ผมก็ลองใส่ .select ทั้งใน module แล้วก็ใน even change แล้วทั้ง 2 ตัว ก็ยังไม่ได้อยู่ดี หรือ สลับใส่อันใดอันหนึ่งก็ไม่ได้ ผมก็จนปัญญาละครับ
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#14
Post
by snasui » Sat Aug 11, 2018 2:32 pm
ผมหมายถึงว่าให้เพิ่ม Event เข้าไปแล้วสังเกตว่าอันไหนมันทำงานจากสแกนก็ให้ดักที่อันนั้น
Event ของ Worksheet มีจำนวนมากไม่ใชเฉพาะ Selection_Change และ Worksheet_Change ลองเพิ่มเข้าไปและทดสอบดู Event ไหนทำงานจากการใช้ตัว Scan ครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#15
Post
by lnongkungl » Sat Aug 11, 2018 2:53 pm
โอ....คงไล่กันยาว ครับเดี๋ยวลองดูครับ
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#16
Post
by snasui » Sat Aug 11, 2018 3:05 pm
เท่าที่ดูน่าจะมี Calculate, BeforeRightClick, BeforeDoubleclick ที่น่าจะเกี่ยวข้องแต่ก็ถือว่าเป็นทางอ้อม
ควรจะดักได้ตั้งแต่ Worksheet_Change ในกรณีของการ Scan ไม่ทราบว่าเมื่อ Debug แล้ว Code มันทำงานอย่างไร มีการกลับมาเลือก Target แล้วไม่ทำงานหรือว่าไม่เลือก Target ครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#17
Post
by lnongkungl » Sat Aug 11, 2018 3:47 pm
ไม่เลือก Target ครับ เหมือนเราคีย์มือแล้วกด Enter ก็จะเลื่อนลงมา 1 ช่อง
สมมุติ target คือ B5 เมื่อ enter ลงมา คือ C5 แต่อย่างที่แจ้งไปข้างต้นครับ
ใส่ code เมื่อคีย์ข้อมูลแล้ว Enter Cursor ก็ต้องกลับไปเลือกที่ target หรือ B5 ซึ่งผลทดสอบของ code คือ
เมื่อคีย์มือ แล้วกด enter cursor ก็อยู่ที่ B5 ที่เดิม ตาม code ที่เราใส่ไว้ แต่พอใช้เครื่องยิงบาร์โค๊ด cursor กลับไม่อยู่ที่เดิม ตาม code ที่เราใส่ไป กลับเลื่อนลงมาที่ C5 เหมือน enter 1 ครั้ง ครับ
snasui
Site Admin
Posts: 31153 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#18
Post
by snasui » Sat Aug 11, 2018 4:18 pm
เข้าใจและช่วยไม่ได้ครับ ถ้าคีย์มือแล้วมันเลือก Target ได้ จะกรอกด้วยสิ่งใดมันก็ควรจะเลือก Target ได้ หากเลือกไม่ได้ก็เป็นเรื่องแปลกครับ
lnongkungl
Member
Posts: 92 Joined: Tue Nov 14, 2017 11:04 am
Excel Ver: 2013
#19
Post
by lnongkungl » Sat Aug 11, 2018 4:22 pm
ก็นี่แหละครับ ที่ทำให้มึน เพราะคีย์มือมันทำได้ แต่ทำไมกับเครื่องยิงบาร์โค๊ด ถึงใช้ไม่ได้
menem
Silver
Posts: 549 Joined: Mon Jan 26, 2015 11:02 am
#20
Post
by menem » Tue Aug 14, 2018 2:24 pm
เท่าที่ทราบ อุปกรณ์ (เครื่องยิงบาร์โค๊ด) จะมี Option ในตัวว่าจะให้แทรก LF เข้าไปหลังจากอ่านค่าหรือเปล่า
(คือจะมีทั้ง CR/LF) ดังนั้น โดยปกติ เวลาเราป้อนผ่าน Keyboard จะมีการกด Enter ซึ่งก็คือ CR แต่เครื่องยิง
จะมีการเพิ่ม LF เข้าไปให้อีกหนึ่งอัน ทำให้มันกลายเป็นว่า จังหวะวที่ส่ง CR Cursor จะเป็นไปตามที่เขียนใน VBA
แต่หลังจากนั้นจะมี LF ทำให้ Cursor เลื่อนลงไปอีก 1 ช่องครับ
ลองตรวจสอบวิธีการตั้งค่าเครื่องยิงบาร์โค๊ดอีกทีนะครับ