ดาวน์โหลดงานนำเสนอ
งานนำเสนอกำลังจะดาวน์โหลด โปรดรอ
1
การเลื่อน Cell และคำสั่งใน Macro
บทที่ 2 การเลื่อน Cell และคำสั่งใน Macro อ.สุรินทร์ทิพ ศักดิ์ภูวดล สำนักวิชาเทคโนโลยีสารสนเทศและการสื่อสาร
2
VBA และ Macro VBA (Visual Basic for Application) เป็นเครื่องมือที่ใช้พัฒนา Application ใน Microsoft Office โดยใช้ภาษา Visual Basic แมโคร (Macro) เป็นสามารถบันทึกการทำงานที่เกิดขึ้นจริงก่อน แล้วจึงเรียกมาใช้งานภายหลัง ซึ่งโปรแกรมจะสร้างคำสั่งเป็นภาษา VBA ให้อัตโนมัติ โดยสามารถแก้ไขเพิ่มเติมคำสั่งได้ Form การทำงานในรูปแบบที่เป็น Graphic มากขึ้นสามารถใช้ Form มารับค่าต่างๆ และนำไปประมวลผล และนำมาจัดการกับ Cell ต่างๆใน Excel ได้ ซึ่งภาษาที่ใช้พัฒนา Application คือ VBA โดยผู้พัฒนาสามารถเขียนคำสั่งเองทั้งหมด
3
โพรซีเยอร์ (Procedures)
เป็นชุดคำสั่งที่ควบคุมการทำงานใน Application แบ่งเป็น 2 ชนิดคือ 1. ซับโพรซีเยอร์ (Sub Procedure) 2. ฟังก์ชันโพรซีเยอร์ (Function Procedure) การบ้านให้ไปหาว่า 1. ซับโพรซีเยอร์ (Sub Procedure) และ ฟังก์ชันโพรซีเยอร์ (Function Procedure) ต่างกันอย่างไร
4
การไปที่รายการถัดไป การไปที่รายการแบบ Absolute คือการไปที่ Cell เดิมเสมอไม่ว่าจะ Run Macro กี่ครั้ง การไปที่รายการแบบ Relative คือการไปที่ Cell หรือบรรทัดถัดจากข้อมูลที่มีอยู่ในการ Run Macro
5
ให้นิสิตดูขั้นตอนการสร้าง Macro
6
ขั้นตอนการไปแบบ Absolute
1. Click Mouse ที่cell A1 2. Click ปุ่ม Record Macro 3. ตั้งชื่อ Macro “ AbsoluteMove” > OK 4. Click Mouse ที่ B2 5. กด End > กด ลูกศรเลื่อนลง 6. ไม่เลือก Relative Reference (กำหนดการไปแบบ Absolute) 7. กดลูกศรลงอีกครั้ง 8. Stop Recording 9. สร้างปุ่มให้ Macro เลือก Macro ชื่อ AbsoluteMove
7
ขั้นตอนการไปแบบ Relative
1. Click Mouse ที่cell A1 2. Click ปุ่ม Record Macro 3. ตั้งชื่อ Macro “ RelativeMove” > OK 4. Click Mouse ที่ B2 5. กด End > กด ลูกศรเลื่อนลง 6. เลือก Relative Reference (กำหนดการไปแบบ Relative ) 7. กดลูกศรลงอีกครั้ง 8. Stop Recording 9. สร้างปุ่มให้ Macro เลือก Macro ชื่อ RelativeMove
8
การ Copy ผลรวมไปไว้ด้านล่าง 2 บรรทัด (1)
บันทึกข้อมูลใน Excel ตามหน้าจอ
9
การ Copy ผลรวมไปไว้ด้านล่าง 2 บรรทัด (2)
ขั้นตอน 1. Click Mouse ที่cell A1 2. Click ปุ่ม Record Macro 3. ตั้งชื่อ Macro “ CopyFormula” > OK 4. กำหนดการทำงานให้เป็นแบบ Absolute (นั่นคือไม่เลือกปุ่ม Relative Reference ) 5. Click Mouse ที่ B2 6. กด End > กด ลูกศรเลื่อนลง 7. เลือก Relative Reference (กำหนดการไปแบบ Relative ) 8. กด Shift ค้างไว้ + กด End + กด ลูกศรไปทางขวา จากนั้นปล่อย Shift 9. กด Ctrl + c 10. กดลูกศรลง 2 ครั้ง 11. Click เมนู Edit > Past Special.. > Value > OK 12. กด Esc > Click ยกเลิกการเลือก Relative Reference (กำหนดการไปแบบ Absolute ) > Click Mouse ไปที่cell A1 13. Stop Recording 14. สร้างปุ่มให้ Macro เลือก Macro ชื่อ CopyFormula
10
การ Copy ผลรวมไปไว้ด้านล่าง 2 บรรทัด (3)
การทดสอบ Macro แบบที่ 1 1. ให้ลบข้อมูล Cell B8:F8 แล้วกดปุ่ม Copy Formula จะพบว่า Cell B8:F8 กลับมาเหมือนเดิม การทดสอบ Macro แบบที่ 2 1. ให้แทรกรายการเช่น ค่าอาหาร ค่าที่พัก แล้วค่าใช้จ่ายรวมจะคำนวณใหม่ 2. ลบ Cell B10:F10 ตามรูป 3. กดปุ่ม Copy Formula จะพบว่า Cell B10:F10 กลับมาเหมือนเดิม โดยจะเป็นค่าที่ถูกคำนวณขึ้นมาใหม่โดยเป็นค่าใช้จ่ายรวมที่ถูกต้อง
11
คำสั่งใน Excel Range(“Cell”).Select คือ เลือกช่วงของ Cell
เช่น Range(“B2”).Select Range(“A1,A2,B1,B2”).Select Rang(“A1:D1”).Select
12
ให้นิสิตเริ่มทำความเข้าใจคำสั่งที่ Macro สร้างขึ้น และให้ดูว่าคำสั่งต่อไปนี้เป็นคำตอบของแบบฝึกหัดใด
1. Range("B2:H4").Select 2. Range("B2").Select 3. Range("B2,D2,D4,F2,H2").Select Range("H2").Activate
13
แบบฝึกหัด 1 1. Click Mouse ที่cell A1 2. Click ปุ่ม Record Macro
3. ตั้งชื่อ Macro “ Rang_01” > OK 4. Click Mouse ที่ B2 5. Stop Recording 6. ให้ดูคำสั่งแล้วเติมคำตอบ
14
แบบฝึกหัด 2 1. Click Mouse ที่cell A1 2. Click ปุ่ม Record Macro
3. ตั้งชื่อ Macro “ Rang_02” > OK 4. Click Mouse ที่ B2 5. กด Ctrl แล้วเลือก D2, D4,F2, H2 6. Stop Recording 7. ให้ดูคำสั่งแล้วเติมคำตอบ
15
แบบฝึกหัด 3 1. Click Mouse ที่cell A1 2. Click ปุ่ม Record Macro
3. ตั้งชื่อ Macro “ Rang_03” > OK 4. Click Mouse ที่ B2 5. กด Shift แล้วเลือก B2 ถึง H4 6. Stop Recording 7. ให้ดูคำสั่งแล้วเติมคำตอบ
16
ให้นิสิตทำแบบฝึกหัดและสังเกตุคำสั่งที่เกิดขึ้น และดูความหมายของคำสั่ง
17
การเลื่อน Cell แบบ Absolute
(Macro1) 1. Range("C11").Select เริ่มเลือกที่ Cell C11 2. Selection.End(xlDown).Select กด End แล้วกด Down 1 ครั้ง 3. Range("C14:D14").Select เลือกใน Mode Absolute โดย (กด Ship + >) ความหมายของโปรแกรมคือเลือกเท่านั้น เหตุการณ์ในการทำงาน 1. ไปที่ A1 2. Record Macro (Macro1) 3. เริ่มต้นเลือกที่ Cell C11 4. กด End แล้ว กดลูกศรลง 5. กด Ship + ลูกศรไปทางขวา (เลือก Cell C14:D14) 6. Stop Recording
18
การเลื่อน Cell แบบ Absolute
(Macro2) Range("C11").Select Selection.End(xlDown).Select Range(Selection, Selection.End(xlToRight)).Select เหตุการณ์ในการทำงาน 1. ไปที่ A1 2. Record Macro (Macro2) 3. เริ่มต้นเลือกที่ Cell C11 4. กด End แล้ว กดลูกศรลง 5. กด Ship + End + ลูกศรไปทางขวา 6. Stop Recording
19
การเลื่อน Cell แบบ Relative
(Macro3) Range("C11").Select Selection.End(xlDown).Select ActiveCell.Range("A1:B1").Select เหตุการณ์ในการทำงาน 1. ไปที่ A1 2. Record Macro (Macro3) 3. เริ่มต้นเลือกที่ Cell C11 4. กด End แล้ว กดลูกศรลง ทำให้ ActiveCell อยู่ที่ C14 5. เลือก Relative Reference 6. กด Ship + ลูกศรไปทางขวา (เลือก Cell C14:D14) 7. Stop Recording
20
การเลื่อน Cell แบบ Relative
(Macro4) Range("C11").Select Selection.End(xlDown).Select Range(Selection, Selection.End(xlToRight)).Select เหตุการณ์ในการทำงาน 1. ไปที่ A1 2. Record Macro (Macro4) 3. เริ่มต้นเลือกที่ Cell C11 4. กด End แล้ว กดลูกศรลง ทำให้ ActiveCell อยู่ที่ C14 5. เลือก Relative Reference 6. กด Ship +End+ ลูกศรไปทางขวา (เลือก Cell C14:D14) 7. Stop Recording
21
การเคลื่อนย้ายไปยัง Cell ที่ว่างหลังข้อมูลแบบ Relative
Sub GotoNewCellRelative() Range("B2").Select Selection.End(xlDown).Select ActiveCell.Offset(1, 0).Range("A1").Select End Sub เหตุการณ์ในการทำงาน 1. ไปที่ A1 2. Record Macro (GotoNewCellRelative) 3. เริ่มต้นเลือกที่ Cell B2 4. กด End แล้ว กดลูกศรลง ทำให้ ActiveCell อยู่ที่ B6 5. เลือก Relative Reference 6. เลื่อนลูกศรลงอีกครั้ง 7. Stop Recording
22
การเคลื่อนย้ายไปยัง Cell ที่ว่างหลังข้อมูลแบบ Absolute
Sub GotoNewCellAbsolute() Range("B2").Select Selection.End(xlDown).Select Range("B7").Select End Sub ขั้นตอนในการทำงาน 1. ไปที่ A1 2. Record Macro (GotoNewCellAbsolute) 3. เริ่มต้นเลือกที่ Cell B2 4. กด End แล้ว กดลูกศรลง ทำให้ ActiveCell อยู่ที่ B6 5. เลือก Relative Reference เพื่อยกเลิก (เพราะต้องการให้เป็น absolute แต่ถ้าเป็น Absolute อยู่ก่อนแล้ว คือปุ่มนั้นไม่ได้เลือกอยู่ก่อนแล้วให้ข้ามไปไม่ต้องเลือกอะไรเลย) 6. เลื่อนลูกศรลงอีกครั้ง 7. Stop Recording
23
สรุปคำสั่ง Activecell = Cell ที่กำลังทำงานอยู่
Activecell.offset(1,0).Range(“A1”).Select เป็นคำสั่งให้กระโดดไปแบบ Relative โดยที่ใน (1,0) หมายถึง ให้เลื่อนไป 1 Row 0 Column จากที่ Activecell ตำแหน่ง(Row,Column) Row เป็นบวก จะเลื่อนลง Row เป็นลบ จะเลื่อนขึ้น Column เป็นบวก จะเลื่อนไปทางขวามือ Column เป็นลบ จะเลื่อนไปทางซ้ายมือ นั่นคือ ถ้าตัวเลขเป็นบวก จะเป็นการเลื่อนลง หรือไปทางขวามือ ถ้าตัวเลขเป็นลบ จะเป็นการเลื่อนขึ้นหรือไปทางซ้ายมือ
24
สรุปคำสั่ง กดปุ่ม End แล้วกดปุ่มลูกศรลง - Selection.End(xlDown).Select
- Selection.End(xlUp).Select กดปุ่ม End แล้วกดปุ่มลูกศรไปทางขวา - Selection.End(xlToRight).Select กดปุ่ม End แล้วกดปุ่มลูกศรไปทางซ้าย - Selection.End(xlToLeft).Select
25
สรุปคำสั่ง คำสั่งบอกตำแหน่ง Cell ActiveCell.Address
26
การรับค่าและแสดงค่าของ Excal
Range("D3").Select ตัวแปร 1 = ActiveCell.Value ตัวแปร 2 = ActiveCell.Offset(0, 1).Value ตัวแปร 3 = ActiveCell.Offset(0, 2).Value การแสดงค่าของ Excal ActiveCell.Value = ค่า1 ActiveCell.Offset(0, 1).Value = ค่า2 ActiveCell.Offset(0, 2).Value = ค่า3
27
การรับค่าและแสดงค่าของ Excal
Sub calTotAmt() Range("D3").Select Do While Not IsEmpty(ActiveCell.Value) Price = ActiveCell.Value BalQty = ActiveCell.Offset(0, 1).Value ActiveCell.Offset(0, 2).Value = Price * BalQty ActiveCell.Offset(1, 0).Select Loop End Sub
28
หนังสืออ้างอิง เรียนลัด VBA บน Excel, วิศัลย์ พัวรุ่งโรจน์
Excel VBA Programming, วิชา ศิริธรรมจักร์ และสุรเชษฐ์ วงศ์ชัยพรพงษ์
งานนำเสนอที่คล้ายกัน
© 2024 SlidePlayer.in.th Inc.
All rights reserved.