snasui.com ยินดีต้อนรับ
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ ระบุ Version ของ Excel
คำแสดงเจตนา
ขอผลแห่งการให้ความรู้นี้ จงกลับไปยังผู้ที่เป็นเจ้าของเดิม แม้ข้าพเจ้าจะไม่รู้จักท่านก็ตาม ขอให้แสงแห่งปัญญาที่ท่านเคยจุดไว้ ได้กลับไปเติมเต็มชีวิตของท่านอีกครั้ง และขอให้เจตนาของข้าพเจ้าเป็นการคืนความดีอย่างสงบ
ฟอรัมถาม-ตอบปัญหาการใช้งาน Macro และ 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] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
maroot610
Member
Posts: 28 Joined: Fri Aug 17, 2018 1:50 pm
#1
Post
by maroot610 » Wed Mar 20, 2019 3:00 pm
อันนี้คือ โค้ดที่ใช้งานครับ
อ้างอิงจาก
https://www.snasui.com/viewtopic.php?f= ... int#p37881
Code: Select all
Sub Print_List()
Dim strValidationRange As String
Dim rngValidation As Range
Dim rngDepartment As Range
Application.ScreenUpdating = False
strValidationRange = Range("n4").Validation.Formula1
Set rngValidation = Range(strValidationRange)
For Each rngDepartment In rngValidation.Cells
Range("n4").Value = rngDepartment.Value
ActiveSheet.PrintOut
Next
Application.ScreenUpdating = True
End Sub
ผมต้องการเวลากด print แล้วปริ้นข้อมูลทั้งหมดที่มีอยู่ ใน รายการ Drop down list มาครับ เช่น แผ่นที่ 1 นาย ก แผ่นที่ 2 นาย ข โดยทำการกดที่ปุ่ม print แค่ครั้งเดียว ไม่ต้องมาเลือก Drop down list อีกครั้ง ครับ
ขอบคุณครับ
Attachments
เงินเดือนnew.xls
(42.5 KiB) Downloaded 4 times
Last edited by
maroot610 on Wed Mar 20, 2019 3:27 pm, edited 1 time in total.
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#2
Post
by puriwutpokin » Wed Mar 20, 2019 3:12 pm
ไฟล์ที่ จะเก็บโค้ด ได้ต้องเป็นไฟล์นามสกุล .xls,.xlsb หรือ .xlsm ครับ ถ้านามสกุล .xlsx เก็บโค้ดไม่ได้ครับลองดูใหม่ครับ
maroot610
Member
Posts: 28 Joined: Fri Aug 17, 2018 1:50 pm
#3
Post
by maroot610 » Wed Mar 20, 2019 3:28 pm
puriwutpokin wrote: Wed Mar 20, 2019 3:12 pm
ไฟล์ที่ จะเก็บโค้ด ได้ต้องเป็นไฟล์นามสกุล .xls,.xlsb หรือ .xlsm ครับ ถ้านามสกุล .xlsx เก็บโค้ดไม่ได้ครับลองดูใหม่ครับ
ขอโทษครับ แก้ไขแล้วครับ
maroot610
Member
Posts: 28 Joined: Fri Aug 17, 2018 1:50 pm
#4
Post
by maroot610 » Wed Mar 20, 2019 3:33 pm
ตรง Drop down list ไม่ยอมทำงาน นะครับ
Attachments
Untitled.png (9.04 KiB) Viewed 52 times
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#5
Post
by puriwutpokin » Wed Mar 20, 2019 4:32 pm
ปรับเป็น จาก
เป็น
ทั้งหมดครับ 2 จุดส่วน
ส่วน Validate รายการหายไป สร้างใหม่ด้วยครับ
เป็น =OFFSET(รายชื่อ!B2,,,COUNTA(รายชื่อ!B:B)-1)
Last edited by
puriwutpokin on Wed Mar 20, 2019 4:43 pm, edited 1 time in total.
maroot610
Member
Posts: 28 Joined: Fri Aug 17, 2018 1:50 pm
#6
Post
by maroot610 » Wed Mar 20, 2019 4:40 pm
puriwutpokin wrote: Wed Mar 20, 2019 4:32 pm
ปรับเป็น จาก
เป็น
ทั้งหมดครับ 2 จุดส่วน
ส่วน Validate รายการหายไป สร้างใหม่ด้วยครับ
เป็น =OFFSET(รายชื่อ!B1,,,COUNTA(รายชื่อ!B:B))
ขอบคุณครับ
Validate พอ save แล้วกลับมาเปิด จะหายไปครับ
ส่วนโค้ด ยังไม่ได้ ครับ
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#7
Post
by puriwutpokin » Wed Mar 20, 2019 4:48 pm
ผมเปลี่ยนสกุลไฟล์ เป็น .xlsm แล้ว และ แอด VBA ที่ปุ๋มแล้วครับ ลองดูตามไฟล์แนบครับ
Attachments
เงินเดือนnew.xlsm
(22.27 KiB) Downloaded 9 times
maroot610
Member
Posts: 28 Joined: Fri Aug 17, 2018 1:50 pm
#8
Post
by maroot610 » Wed Mar 20, 2019 5:00 pm
puriwutpokin wrote: Wed Mar 20, 2019 4:48 pm
ผมเปลี่ยนสกุลไฟล์ เป็น .xlsm แล้ว และ แอด VBA ที่ปุ๋มแล้วครับ ลองดูตามไฟล์แนบครับ
ขอบคุณมาก เลยครับ