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] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
pongpang
Member
Posts: 242 Joined: Fri Jul 05, 2013 9:35 pm
#1
Post
by pongpang » Mon Sep 30, 2013 3:03 pm
Code in Moule
Code: Select all
Sub act()
Range("f1").Select
ActiveCell.Value = 25
Cells(6, 13).Select
ActiveCell.Value = "OK"
End Sub
Code inworksheets
Code: Select all
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Range("f1").Select Then
ActiveCell.Value = 11
ElseIf Range("f13").Select Then
ActiveCell.Value = 20
Exit Sub
End If
End Sub
ปัญหา คือ ไม่สามารถคลิกที่เซลใดๆได้ เลือกได้เพียงเซลเดียวครับ และค่าที่กำหนดในเซลอื่นก็ไม่แสดงค่าตามที่กำหนด ครับ
ความต้องการ คือ ที่กำหนดไว้ถ้าคลิกที่F1แล้วแสดงค่า และให้คลิกเลือกที่เซลอื่นได้ด้วยในที่นี้ คือ เซล F13 พร้อมกับให้แสดงค่าตามที่กำหนดไว้ ครับ
ไม่ทราบว่า จะปรับปรุงCodeอย่างไร ครับ
Attachments
สมุดงาน1.xlsm
(19.99 KiB) Downloaded 14 times
snasui
Site Admin
Posts: 31253 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#2
Post
by snasui » Mon Sep 30, 2013 3:51 pm
ลองปรับ Code เป็นตามด้านล่างครับ
Code: Select all
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Target.Address = Range("f1").Address Then
ActiveCell.Value = 11
ElseIf Target.Address = Range("f13").Address Then
ActiveCell.Value = 20
Exit Sub
End If
End Sub
pongpang
Member
Posts: 242 Joined: Fri Jul 05, 2013 9:35 pm
#3
Post
by pongpang » Mon Sep 30, 2013 4:05 pm
ขอบคุณ คุณคนควน มากครับ