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] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#1
Post
by akekorn » Thu Nov 14, 2019 9:12 pm
สวัสดีครับเพื่อนสมาชิกทุกท่าน
วันนี้ผมมีปัญหา เกี่ยวกับ การจัดทำข้อมูลที่อยู่ภายใน column เดียว แต่จำเป็นต้องกลับให้เป็นรูปแบบตารางเพื่อนำไปใช้งานด้านอื่น
ผมเริ่มเขียน Vba แต่ติดปัญหาไม่ทราบว่าจะเขียน ให้กลับด้านข้อมูลที่เป็นแนว column ให้เป็นตาราง และเรียงต่อกันลงมาได้อย่างไร
โดยผมได้แนบตัวอย่างที่ต้องการมาด้วย
ในตัวอย่างข่อมูลที่ต้องกลับให้เป็นแบบตารางอยู่ท่ี่sheet1 cell A2:A131 ต้องเลือกทุก 5 บรรทัดเพื่อวางใน cell D:H และวางทีละบรรทัด
ลงมาเรื่อยๆจนข้อมูลถึงบรรทัดสุดท่้าย
ผมขอความอนุเคราะห์ด้วยครับ เพราะจำเป็นต้องรีบส่งงานนี้ คิดมาทั้งวันแต่เขียน ไม่ออกจริงๆครับผม
ขอบคุณครับ
Attachments
VB_Table.xlsm
(17.96 KiB) Downloaded 13 times
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#2
Post
by puriwutpokin » Thu Nov 14, 2019 10:43 pm
ตัวอย่างโค้ดครับ
Code: Select all
Sub makedata()
Dim i&, z&, x&
i = Cells(Rows.Count, "a").End(xlUp).row
z = 2: x = 2
While z <= i
Range("d" & x).Resize(, 5) = _
WorksheetFunction.Transpose(Range("a" & z).Resize(5))
z = z + 5: x = x + 1
Wend
End Sub
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#3
Post
by akekorn » Thu Nov 14, 2019 10:51 pm
ขอบคุณมากๆครับผม
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#4
Post
by akekorn » Thu Nov 14, 2019 10:54 pm
รบกวนถามครับการเขียนแบบนี้เรียกว่าอะไรครับ ไม่เคยเห็น coding ลักษณะนี้ครับ
หากจะศึกษาเพิ่มได้จากที่ไหนครับ
ขอบคุณครับ
puriwutpokin
Guru
Posts: 3801 Joined: Fri Jan 04, 2013 9:49 pm
Location: Bangkok
Excel Ver: MS.365
#5
Post
by puriwutpokin » Thu Nov 14, 2019 10:58 pm
Google เลยครับ มีมากมายครับอยู่ที่เราตั้งคำค้นหาและ จะเข้าใจแกะ และใช้คำสั่งเพื่อปรับเข้ากับของเรา หรือก็ลองศึกษา จากหนังสือเบื้องต้นดูครับ
akekorn
Bronze
Posts: 416 Joined: Wed Mar 09, 2011 5:19 pm
#6
Post
by akekorn » Thu Nov 14, 2019 11:00 pm
ครับผมขอบคุณครับ
snasui
Site Admin
Posts: 31214 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#7
Post
by snasui » Fri Nov 15, 2019 6:45 am
แถมอีกแบบเป็นครับ
Code: Select all
Dim k As Long
With Worksheets("Sheet1")
For k = 2 To .Cells(.Rows.Count, 1).End(xlUp).Row Step 5
.Cells((k - 2) \ 5 + 2, "d").Resize(1, 5).Value = _
Application.Transpose(.Cells(k, "a").Resize(5).Value)
Next k
End With