:D snasui.com ยินดีต้อนรับ :D
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย :thup: สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ :arrow: ระบุ Version ของ Excel
:!: โปรดทราบ :!:
  1. กรุณาอ่านกฎการใช้บอร์ด (Forum rules) ในตำแหน่งด้านบนของแต่ละบอร์ด
  2. การสมัครสมาชิก การ Login การกู้คืนรหัสผ่าน
    1. สมัครสมาชิกดูขั้นตอนได้ที่ :arrow: สมัครสมาชิก
    2. Login เข้าระบบโดยคลิกปุ่ม Login ตรงมุมขวาบนของหน้านี้ :roll:
    3. การ Login ผ่าน Facebook ดูวิธีที่ :arrow: Login ผ่าน Facebook
    4. ลืมรหัสผ่านสามารถรับรหัสใหม่ได้ที่ :arrow: Reset รหัสผ่าน
  3. มีปัญหาการใช้งาน แจ้งผู้ดูแลระบบได้ที่ :arrow: ติดต่อผู้ดูแลระบบ
  4. กำหนดการตั้งค่าส่วนตัว เช่นตั้งค่าภาษาเป็นไทยหรืออังกฤษดูได้ที่ :arrow: ตั้งค่าส่วนตัว
  5. การตั้งและตอบกระทู้ดูได้ที่ :arrow: วิธีการตั้งและตอบกระทู้
  6. การจัดรูปแบบตัวอักษรด้วย bbcode ในช่องแสดงความคิดเห็นดูได้ที่ :arrow: จัดรูปแบบตัวอักษร
  7. กำหนดขนาดตัวอักษรใน Browser ดูได้ที่ :arrow: กำหนดขนาดตัวอักษรใน Browser
🪷 คำแสดงเจตนา
ขอผลแห่งการให้ความรู้นี้ จงกลับไปยังผู้ที่เป็นเจ้าของเดิม แม้ข้าพเจ้าจะไม่รู้จักท่านก็ตาม ขอให้แสงแห่งปัญญาที่ท่านเคยจุดไว้ ได้กลับไปเติมเต็มชีวิตของท่านอีกครั้ง และขอให้เจตนาของข้าพเจ้าเป็นการคืนความดีอย่างสงบ

การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

ฟอรัมถาม-ตอบปัญหาการใช้งาน MS Excel and VBA
Forum rules
  1. ไม่อนุญาตให้ใช้ภาษาแชทในการถามและตอบปัญหา ไม่ใช้คำว่า "คับ" หรือ "อ่ะครับ" แทนคำว่า "ครับ" ไม่ใช้คำว่า "เด๋ว" แทนคำว่า "เดี๋ยว" เป็นต้น เนื่องจากเมื่อแปลเป็นภาษาต่างประเทศแล้วจะให้ความหมายผิดไปจากที่ควรจะเป็น
  2. ห้ามถามโดยระบุชื่อผู้ตอบและต้องตั้งชื่อกระทู้ให้สื่อถึงปัญหาที่จะถาม ไม่ตั้งชื่อว่า ช่วยด้วยครับ, มีปัญหามาปรึกษาครับ เป็นต้น
  3. กรุณาอธิบายปัญหาและระบุคำตอบที่ต้องการมาในกระทู้ด้วยเสมอถึงแม้จะอธิบายไว้ในไฟล์แนบแล้วก็ตาม ทั้งนี้เพื่ออำนวยความสะดวกแก่เพื่อนสมาชิกในการค้นหาข้อมูล
  4. กรุณาแนบไฟล์ตัวอย่างพร้อมแสดงคำตอบที่ถูกต้องมาในไฟล์ด้วยเพื่อให้ง่ายต่อการทำความเข้าใจและสะดวกต่อการตอบคำถาม (ขนาดไฟล์ไม่เกิน 500Kb ขนาดภาพไม่เกิน 800*600 Pixel) ไม่แนบเป็น Link มาจากแหล่งอื่นที่อาจจะถูกลบทิ้งไปโดยต้นทางในภายหลัง นอกจากนี้ไม่ควรแนบไฟล์ที่มีข้อมูลสำคัญอันก่อให้เกิดความเสียหายกับตนเองและผู้อื่น
  5. กรณีเป็นคำถามเกี่ยวกับ Programming เช่น VBA, VB.Net, C#, SQL ฯลฯ ต้องลองเขียนมาเองก่อนเสมอ ถามเฉพาะที่ติดปัญหา ระบุ Module, Procedure ที่ติดปัญหาให้ชัดเจน กรุณาโพสต์ Code ให้แสดงเป็น Code คือเปิดด้วย [code] และปิดด้วย [/code] ตัวอย่างเช่น [code]dim r as range[/code] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
  6. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
Kanok
Member
Member
Posts: 31
Joined: Sat Jul 23, 2016 10:34 am

การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#1

Post by Kanok »

้ต้องการเปลี่ยนข้อูลในเซลล์ของ Excel โดยเลือกข้อมูลตั้งแต่ AE2 จนถึงแถว และคอลัมภ์สุดท้าย ให้เป็น "X"

โดยมี Code ดังนี้ :
เปลี่ยนข้อมูลในคอลัมภ์ เป็น X.jpg

Code: Select all

Sub A3_ChangeNumberToX2()

Dim i As Long
Dim j As Long
Dim lastrow As Long
Dim lastcolumn As Long

Sheets("Sheet1").Select

lastrow = Sheets("Sheet1").Cells(Rows.Count, 1).End(xlUp).Row
lastcolumn = Sheets("Sheet1").Cells(31, Columns.Count).End(xlToRight).Column

For j = 31 To lastcolumn
    For i = 2 To lastrow
    If Cells(i, j).Value <> "" Then
    
        Cells(i, j).Value = "X"
        End If
     Next i

Next j

End Sub


Code สามารถรันได้ในบางครั้ง ซึ่งใช้เวลานาน ประมาณ 2-3 นาที ค่ะ
และบางครั้งก็มีการค้างระหว่างการรันโปรแกรม

และในบางครั้งกรณีไม่สาารถรันได้จนจบโปรแกรม
อยากจะสอบถาว่าพอมีวิธีที่จะช่วยให้โปรแกรมสามารถทำงานได้เร็วขึ้นไหมค่ะ

เอกสารแนบค่ะ -->
Aเปลี่ยนข้อมูลในตารางเป็น X copy2 macro.xlsm
You do not have the required permissions to view the files attached to this post.
User avatar
snasui
Site Admin
Site Admin
Posts: 31175
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#2

Post by snasui »

:D ตัวอย่าง Code ครับ

Code: Select all

Sub A3_ChangeNumberToX2()
   Range("ae2").Resize(100000, 10000).SpecialCells(xlCellTypeConstants).Value = "X"
End Sub
สามารถเปลี่ยนตัวเลข 100000, 10000 ไปเป็นค่าที่ต้องการ โดยต้องปรับ 100000 เป็นค่าที่ไม่เกินจำนวนบรรทัดที่สามารถมีได้ และปรับ 10000 เป็นค่าคอลัมน์ที่โปรแกรมสามารถมีได้ เนื่องจาก Excel Version 2003 ลงไปมีจำนวนบรรทัดและคอลัมน์เพียง 65536 และ 256 ตามลำดับ
Kanok
Member
Member
Posts: 31
Joined: Sat Jul 23, 2016 10:34 am

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#3

Post by Kanok »

snasui wrote::D ตัวอย่าง Code ครับ

Code: Select all

Sub A3_ChangeNumberToX2()
   Range("ae2").Resize(100000, 10000).SpecialCells(xlCellTypeConstants).Value = "X"
End Sub
สามารถเปลี่ยนตัวเลข 100000, 10000 ไปเป็นค่าที่ต้องการ โดยต้องปรับ 100000 เป็นค่าที่ไม่เกินจำนวนบรรทัดที่สามารถมีได้ และปรับ 10000 เป็นค่าคอลัมน์ที่โปรแกรมสามารถมีได้ เนื่องจาก Excel Version 2003 ลงไปมีจำนวนบรรทัดและคอลัมน์เพียง 65536 และ 256 ตามลำดับ

:D ขอบคุณสำหรับคำชี้แนะค่ะ :D

รบกวนสอบถาเพิ่มเติมค่ะ ในกรณีที่เราไม่ต้องการเปลี่ยนค่าเป็น X ทุกเซลล์ แต่จะเปลี่ยนเฉพาะเซลล์ที่มีข้อมูลเท่านั้น
ซึ่งเซลล์ที่ไม่มีข้อมูลก็ปล่อให้เป็นเซลล์ว่าง ไม่ทราบว่าจะแก้ไขโค้ดให้ทำงานได้เร็วขึ้นได้อย่างไรคะ
Pic1.jpg

ปล.) ต้องขออภัยที่ไม่ได้ชี้แจงรายละเอียดของคำถามให้ชัดเจนในคำถามแรกค่ะ
You do not have the required permissions to view the files attached to this post.
User avatar
snasui
Site Admin
Site Admin
Posts: 31175
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#4

Post by snasui »

:D Code นั้นเปลี่ยนเฉพาะเซลล์ที่มีข้อมูลหรือเซลล์ที่ไม่ว่าง หากเซลล์ใดมองเห็นด้วยตาว่าไม่มีข้อมูลแต่เห็นเป็นค่า X หลังจาก Run Code แสดงว่าเซลล์นั้นไม่ใช่เซลล์ว่างจริง ๆ ให้ทำการ Clear ให้เป็นค่าว่างจริง ๆ เสียก่อนด้วยวิธีการใด ๆ ครับ
Kanok
Member
Member
Posts: 31
Joined: Sat Jul 23, 2016 10:34 am

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#5

Post by Kanok »

snasui wrote::D Code นั้นเปลี่ยนเฉพาะเซลล์ที่มีข้อมูลหรือเซลล์ที่ไม่ว่าง หากเซลล์ใดมองเห็นด้วยตาว่าไม่มีข้อมูลแต่เห็นเป็นค่า X หลังจาก Run Code แสดงว่าเซลล์นั้นไม่ใช่เซลล์ว่างจริง ๆ ให้ทำการ Clear ให้เป็นค่าว่างจริง ๆ เสียก่อนด้วยวิธีการใด ๆ ครับ

ขอบคุณมากค่ะ สำหรับคำชี้แนะ :D :D
Kanok
Member
Member
Posts: 31
Joined: Sat Jul 23, 2016 10:34 am

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#6

Post by Kanok »

snasui wrote::D Code นั้นเปลี่ยนเฉพาะเซลล์ที่มีข้อมูลหรือเซลล์ที่ไม่ว่าง หากเซลล์ใดมองเห็นด้วยตาว่าไม่มีข้อมูลแต่เห็นเป็นค่า X หลังจาก Run Code แสดงว่าเซลล์นั้นไม่ใช่เซลล์ว่างจริง ๆ ให้ทำการ Clear ให้เป็นค่าว่างจริง ๆ เสียก่อนด้วยวิธีการใด ๆ ครับ
รบกวนสอบถามอาจารย์เพิ่มเติมค่ะ

คือ ได้ทำการแก้ไขโค้ดตามที่อาจารย์แนะนำ โดยเปลี่ยนค่าในช่องที่ตาเรามองเห็นว่าเป็นเซลล์ที่ไม่มีข้อมูล ให้เป็นเซลล์ว่างจริงๆ
โดยใช้คำสั่ง .clearcontents และสั่งให้วนลูป เพื่อทำการเปลี่ยนเซลล์ที่ไม่มีข้อมูลให้เป็นเซลล์ว่างจริงๆ
หลังจากนั้น ใช้คำสั่งที่อาจารย์แนะนำ เปลี่ยนเซลล์ที่มีข้อมูลให้เป็น "X" ตามที่ต้องการ

แต่ใช้เวลารันโปรแกรมค่อนข้างนานค่ะ ประมาณ 15 นาที ในการเปลี่ยนเเซลล์ที่ไม่เห็นข้อมูล เป็นเซลล์ว่างจริงๆ สำหรับข้อมูลที่มีขนาดตาราง 83x324 ค่ะ

Code: Select all

Sub A3_ChangeNumberToX4()

Dim i As Long
Dim j As Long
Dim lastrow As Long
Dim lastcolumn As Long


Sheets("Sheet2").Select

lastrow = Sheets("Sheet2").Cells(Rows.Count, 1).End(xlUp).Row
lastcolumn = Sheets("Sheet2").Cells(27, Columns.Count).End(xlToRight).Column

For j = 31 To lastcolumn
    For i = 2 To lastrow
    If Cells(i, j).Value = "" Then
    
       Cells(i, j).ClearContents
    
        End If
Next i

Next j

 Range("ae2").Resize(100000, 10000).SpecialCells(xlCellTypeConstants).Value = "X"


End Sub

รบกวนขอคำแนะนำในการแก้ไขโปรแกรม ให้ทำงานได้เร็วขึ้นด้วยค่ะ
User avatar
DhitiBank
Gold
Gold
Posts: 1676
Joined: Mon Oct 15, 2012 12:07 am

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#7

Post by DhitiBank »

ปรับโค้ดตรง
lastcolumn = Sheets("Sheet1").Cells(1, Columns.Count).End(xlToRight).Column
เป็น
lastcolumn = Sheets("Sheet1").Cells(1, Columns.Count).End(xlTo[color=#FF0000]Left[/color]).Column
ครับ

แล้วก็ หลังประกาศตัวแปรให้เพิ่ม
Application.Calculation = xlCalculationManual เพื่อหยุดการคำนวณ (เมื่อเปลี่ยนแปลงค่าในเซลล์ตอนลูปจะได้ไม่ต้องคำนวณ)
จากนั้น ก่อนที่จะถึงบรรทัด End Sub ก็ใส่
Application.Calculation = xlCalculationAutomatic เพื่อสั่งให้กลับมาคำนวณแบบอัตโนมัติครับ
Kanok
Member
Member
Posts: 31
Joined: Sat Jul 23, 2016 10:34 am

Re: การเปลี่ยนข้อมูลในเซลล์ Excel (VBA)

#8

Post by Kanok »

DhitiBank wrote:ปรับโค้ดตรง
lastcolumn = Sheets("Sheet1").Cells(1, Columns.Count).End(xlToRight).Column
เป็น
lastcolumn = Sheets("Sheet1").Cells(1, Columns.Count).End(xlTo[color=#FF0000]Left[/color]).Column
ครับ

แล้วก็ หลังประกาศตัวแปรให้เพิ่ม
Application.Calculation = xlCalculationManual เพื่อหยุดการคำนวณ (เมื่อเปลี่ยนแปลงค่าในเซลล์ตอนลูปจะได้ไม่ต้องคำนวณ)
จากนั้น ก่อนที่จะถึงบรรทัด End Sub ก็ใส่
Application.Calculation = xlCalculationAutomatic เพื่อสั่งให้กลับมาคำนวณแบบอัตโนมัติครับ


ขอบคุณมากค่ะ สามารถรันได้เร็วขึ้นกว่าเดิม มากๆเลยค่ะ :D
Post Reply