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] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#1
Post
by akekorn » Wed Oct 29, 2014 1:15 pm
สวัสดีครับสมาชิกทกท่าน
ผมมีปัญหาในการใช้ โค๊ดคือ ต้องการการให้ print ใบเสร็จ แต่พอโปรแกรมทำงานแรกเสร็จเหมือนจะย้อนกลับมาหา file หลักไม่ได้ โดยมันจะขึ้น error subscript out of range ไม่ทราบว่าควรแก้ไขอย่างไรครับ โดยได้แนบโค๊ดมาด้วยครับ
Code: Select all
Sub Macro4E()
Rows("5:5").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("5:5").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("6:6").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("6:6").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("7:7").Select
Selection.Copy
Windows("RENT.XLS").Activate
Rows("17:17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("7:7").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Rows("17:17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("8:8").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("8:8").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
'Rows("21:21").Select
'Selection.Copy
' Windows("RENT.XLS").Activate
'Range("A17").Select
'ActiveSheet.Paste
'Application.CutCopyMode = False
'ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("9:9").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("9:9").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("10:10").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("10:10").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("11:11").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("11:11").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("11:12").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("11:12").Select
Selection.Copy
Windows("BILL13N.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("13:13").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("13:13").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("14:14").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("14:14").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("15:15").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("15:15").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("16:16").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("16:16").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("17:17").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("17:17").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("18:18").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("18:18").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("19:19").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("19:19").Select
Selection.Copy
Windows("BILL13.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("20:20").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
'Windows("soi1307.xls").Activate
Windows("Program_Label for print label &newbill1311-57.xls").Activate
Rows("20:20").Select
Selection.Copy
Windows("BILL13N.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
End Sub
ขอบคุณครับ
เอก
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#2
Post
by snasui » Wed Oct 29, 2014 1:35 pm
Code Error ที่บรรทัดใด แนบไฟล์ตัวอย่างมาด้วยจะได้ช่วยทดสอบได้ครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#3
Post
by akekorn » Wed Oct 29, 2014 1:42 pm
file แนบครับ
You do not have the required permissions to view the files attached to this post.
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#4
Post
by snasui » Wed Oct 29, 2014 2:02 pm
ช่วยตอบตามที่ผมถาม
เพื่อความรวดเร็วในการเข้าถึงข้อผิดพลาดครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#5
Post
by akekorn » Wed Oct 29, 2014 2:07 pm
ครับคือตอนแรกที่เปิดfile จะเปิดที่ Program_Label for print label &newbill1311-57.xls
แล้วพอรันแล้ว พิมพ์ใบเสร็จแรกได้จะติดที่
Windows("Program_Label for print label &newbill1311-57.xls").Activate
เพราะเหมือนกลับไปที่ file นี้ไม่ได้จึงขึ้น subscript out of range ครับ
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#6
Post
by snasui » Wed Oct 29, 2014 2:14 pm
Code อยู่ในไฟล์ไหนของไฟล์ที่แนบมาครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#7
Post
by akekorn » Wed Oct 29, 2014 2:23 pm
Program_Label for print label &newbill1311-57.xls ครับผม
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#8
Post
by snasui » Wed Oct 29, 2014 2:46 pm
ไฟล์ที่แนบมานามสกุลเป็น .xlsx ช่วยแนบมาใหม่ครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#9
Post
by akekorn » Wed Oct 29, 2014 3:00 pm
ส่งมาแล้วครับ
You do not have the required permissions to view the files attached to this post.
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#10
Post
by snasui » Wed Oct 29, 2014 3:14 pm
ไม่พบ Code ในไฟล์แนบ ไฟล์ที่มีขนาดไม่ถึง 300k ไม่จำเป็นต้อง Zip ครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#11
Post
by akekorn » Wed Oct 29, 2014 3:21 pm
ส่งแล้วครับผม
You do not have the required permissions to view the files attached to this post.
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#12
Post
by snasui » Wed Oct 29, 2014 3:27 pm
ช่วยแจ้งลำดับการทำงานมาด้วย เช่นคลิกปุ่มในในไฟล์ใด ในชีทใด หรืออื่น ๆ ฯลฯ จะได้ทราบว่าต้องทดสอบตามลำดับใดครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#13
Post
by akekorn » Wed Oct 29, 2014 3:34 pm
คือผมจะเปิดทังสาม file พร้อมกัน แต่ให้ active ที่ file Program_Label for print label &newbill1311-57.xls แล้วเลือกมาโคร ก็จะไปที่ บรรทัดที่ 5 ของ file ดังกล่าวเพื่อ copy มาไว้ที่ file RENT.XLS ที่เซล A17 จากนั้นก็จะพิมพ์ใบเสร็จชุดแรกก่อน หลังจากนั้นก็จะกลับไปที่ file Program_Label for print label &newbill1311-57.xls เพื่อที่จะ copy ข้อมูลบรรทัดต่อไป ในช่วงนี้เองครับจะเกิด error subscript out of range ครับ
snasui
Site Admin
Posts: 31257 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#14
Post
by snasui » Wed Oct 29, 2014 3:46 pm
ตัวอย่างการปรับ Code ตามด้านล่าง เป็นการประกาศตัวแปรให้กับ Workbook แล้วค่อยเรียกใช้ครับ
Code: Select all
Sub Macro4E()
Dim p As Workbook
Set p = ThisWorkbook
Rows("5:5").Select
Selection.Copy
Windows("RENT.XLS").Activate
Range("A17").Select
ActiveSheet.Paste
Application.CutCopyMode = False
ActiveWindow.SelectedSheets.PrintOut Copies:=1
' Workbooks("Program_Label for print label &newbill1311-57.xls").Activate
p.Activate
'Other code
End Sub
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#15
Post
by akekorn » Wed Oct 29, 2014 9:01 pm
ครับผมขอบคุณครับผมจะลองปรับดูก่อนนะครับหากมีปัญหาจะสอบถามอีกนะครับผม