Note: The other languages of the website are Google-translated. Back to English
English English

วิธีลบคอลัมน์ทั้งหมดตามค่าส่วนหัวใน Excel

ในหลาย ๆ กรณีคุณอาจต้องลบคอลัมน์ทั้งหมดตามค่าส่วนหัวใน Excel ตัวอย่างเช่นคุณต้องลบคอลัมน์ทั้งหมดที่มีค่า "เก่า" ในส่วนหัว ในบทช่วยสอนนี้เราจะแสดงวิธีการลบคอลัมน์ทั้งหมดตามค่าส่วนหัวโดยละเอียด

ลบคอลัมน์ทั้งหมดตามค่าส่วนหัวด้วยรหัส VBA
ลบคอลัมน์ทั้งหมดตามค่าส่วนหัวด้วย Kutools for Excel


ลบคอลัมน์ทั้งหมดตามค่าส่วนหัวด้วยรหัส VBA

คุณสามารถลบคอลัมน์ทั้งหมดตามค่าส่วนหัวด้วยรหัส VBA กรุณาดำเนินการดังนี้

1 กด อื่น ๆ + F11 พร้อมกันเพื่อเปิดไฟล์ แอปพลิเคชัน Microsoft Visual Basic หน้าต่าง

2 ใน แอปพลิเคชัน Microsoft Visual Basic หน้าต่างคลิก สิ่งที่ใส่เข้าไป > โมดูล. จากนั้นคัดลอกและวางโค้ดด้านล่างลงในหน้าต่างโมดูล

รหัส VBA: ลบคอลัมน์ทั้งหมดตามค่าส่วนหัว

Sub DeleteSpecifcColumn()
	Set MR = Range("A1:D1")
	For Each cell In MR
		If cell.Value = "old" Then cell.EntireColumn.Delete
	Next
End Sub

หมายเหตุ:

1) ในรหัส “เก่า” คือค่าส่วนหัวที่คุณต้องการลบทั้งคอลัมน์โดยยึดตาม โปรดเปลี่ยนเป็นค่าส่วนหัวของคุณด้วยตนเอง และ A1: D1 คือช่วงคอลัมน์ที่คุณต้องการใช้
2) รหัสนี้เป็นตัวพิมพ์เล็กและตัวพิมพ์ใหญ่

3 กด F5 เพื่อเรียกใช้รหัสทั้งคอลัมน์ที่มีส่วนหัวเท่ากับข้อความที่ระบุจะถูกลบออกทันที


ลบคอลัมน์ทั้งหมดตามค่าส่วนหัวด้วย Kutools for Excel

กับ Kutools สำหรับ Excel's เลือกเซลล์เฉพาะ ยูทิลิตี้คุณสามารถเลือกคอลัมน์ทั้งหมดที่มีค่าส่วนหัวที่แน่นอนก่อนจากนั้นจึงลบคอลัมน์ที่เลือกเหล่านี้พร้อมกัน กรุณาดำเนินการดังนี้

ก่อนที่จะใช้ Kutools สำหรับ Excelโปรด ดาวน์โหลดและติดตั้งในตอนแรก.

1. เลือกช่วงที่มีคอลัมน์ที่คุณต้องการลบจากนั้นคลิก Kutools > เลือก > เลือกเซลล์เฉพาะ. ดูภาพหน้าจอ:

2 ใน เลือกเซลล์เฉพาะ กล่องโต้ตอบเลือกไฟล์ คอลัมน์ทั้งหมด ตัวเลือกใน ประเภทการเลือก และในส่วน ประเภทเฉพาะ รายการแบบเลื่อนลงเลือก เท่ากับ จากนั้นพิมพ์ค่าส่วนหัวในช่องต่อไปนี้ และสุดท้ายคลิก OK ปุ่ม. ดูภาพหน้าจอ:

3 คลิกที่ OK ในกล่องโต้ตอบอื่นที่โผล่ขึ้นมาจากนั้นคอลัมน์ที่มีค่าส่วนหัวที่ระบุจะถูกเลือกทันที

4. คลิกขวาที่ส่วนหัวคอลัมน์ของคอลัมน์ที่เลือกแล้วคลิก ลบ จากเมนูคลิกขวา จากนั้นคอลัมน์ที่เลือกทั้งหมดจะถูกลบพร้อมกัน

  หากคุณต้องการทดลองใช้ยูทิลิตีนี้ฟรี (30 วัน) กรุณาคลิกเพื่อดาวน์โหลดแล้วไปใช้การดำเนินการตามขั้นตอนข้างต้น


เครื่องมือเพิ่มประสิทธิภาพการทำงานในสำนักงานที่ดีที่สุด

Kutools สำหรับ Excel ช่วยแก้ปัญหาส่วนใหญ่ของคุณและเพิ่มผลผลิตของคุณได้ถึง 80%

  • นำมาใช้ใหม่: ใส่อย่างรวดเร็ว สูตรที่ซับซ้อนแผนภูมิ และสิ่งที่คุณเคยใช้มาก่อน เข้ารหัสเซลล์ ด้วยรหัสผ่าน; สร้างรายชื่อผู้รับจดหมาย และส่งอีเมล ...
  • ซุปเปอร์ฟอร์มูล่าบาร์ (แก้ไขข้อความและสูตรหลายบรรทัดได้อย่างง่ายดาย); การอ่านเค้าโครง (อ่านและแก้ไขเซลล์จำนวนมากได้อย่างง่ายดาย); วางลงในช่วงที่กรองแล้ว...
  • ผสานเซลล์ / แถว / คอลัมน์ โดยไม่สูญเสียข้อมูล แยกเนื้อหาของเซลล์ รวมแถว / คอลัมน์ที่ซ้ำกัน... ป้องกันเซลล์ซ้ำ; เปรียบเทียบช่วง...
  • เลือกซ้ำหรือไม่ซ้ำ แถว; เลือกแถวว่าง (เซลล์ทั้งหมดว่างเปล่า); Super Find และ Fuzzy Find ในสมุดงานจำนวนมาก สุ่มเลือก ...
  • สำเนาถูกต้อง หลายเซลล์โดยไม่เปลี่ยนการอ้างอิงสูตร สร้างการอ้างอิงอัตโนมัติ ถึงหลายแผ่น ใส่สัญลักษณ์แสดงหัวข้อย่อย, กล่องกาเครื่องหมายและอื่น ๆ ...
  • แยกข้อความ, เพิ่มข้อความ, ลบตามตำแหน่ง, ลบ Space; สร้างและพิมพ์ผลรวมย่อยของเพจ แปลงระหว่างเนื้อหาของเซลล์และความคิดเห็น...
  • ซุปเปอร์ฟิลเตอร์ (บันทึกและใช้โครงร่างตัวกรองกับแผ่นงานอื่น ๆ ); การเรียงลำดับขั้นสูง ตามเดือน / สัปดาห์ / วันความถี่และอื่น ๆ ตัวกรองพิเศษ โดยตัวหนาตัวเอียง ...
  • รวมสมุดงานและแผ่นงาน; ผสานตารางตามคอลัมน์สำคัญ แยกข้อมูลออกเป็นหลายแผ่น; Batch แปลง xls, xlsx และ PDF...
  • คุณสมบัติที่ทรงพลังมากกว่า 300 รายการ. รองรับ Office / Excel 2007-2019 และ 365 รองรับทุกภาษา ใช้งานง่ายในองค์กรหรือองค์กรของคุณ ทดลองใช้ฟรี 30 วันเต็ม รับประกันคืนเงิน 60 วัน
kte แท็บ 201905

แท็บ Office นำอินเทอร์เฟซแบบแท็บมาที่ Office และทำให้งานของคุณง่ายขึ้นมาก

  • เปิดใช้งานการแก้ไขและอ่านแบบแท็บใน Word, Excel, PowerPoint, ผู้จัดพิมพ์, Access, Visio และโครงการ
  • เปิดและสร้างเอกสารหลายรายการในแท็บใหม่ของหน้าต่างเดียวกันแทนที่จะเป็นในหน้าต่างใหม่
  • เพิ่มผลผลิตของคุณ 50% และลดการคลิกเมาส์หลายร้อยครั้งให้คุณทุกวัน!
ด้านล่าง officetab
จัดเรียงความคิดเห็นโดย
ความคิดเห็น (12)
ยังไม่มีการให้คะแนน เป็นคนแรกที่ให้คะแนน!
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ขออภัยหากสิ่งนี้ดูเหมือนพื้นฐานสุด ๆ แต่นี่เป็นครั้งแรกที่ฉันลองใช้ vba ฉันจะใช้มันอย่างไรเพื่อลบส่วนหัวของคอลัมน์หลายรายการ ฉันกำลังพยายามเก็บเฉพาะคอลัมน์ส่วนหัวและลบส่วนที่เหลือของรายการที่เปลี่ยนแปลง
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ในรหัสแรกเพียงคัดลอกแถวที่ 4 และเปลี่ยน "เก่า" เป็นชื่อคอลัมน์ที่สองและจะได้ผล
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
เฮ้! วิธีนี้ใช้ได้ผลดีจนกว่าคุณจะมีสองคอลัมน์ที่อยู่ติดกันที่มีส่วนหัวเดียวกัน สมมติว่าช่วงของคุณคือ A1:A5 และ A2 และ A3 มีส่วนหัว 'เก่า' มันจะลบ A2 แต่แล้ว A3 จะย้ายไปยังตำแหน่งที่ A2 เคยครอบครอง และรหัสจะข้ามไป เนื่องจากมันจะดูที่ A3 ใหม่ ซึ่งเป็นเซลล์ถัดไปในช่วงของมัน
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดีอีเลียส
ตามที่คุณกล่าวถึง A2 และ A3 มีส่วนหัว "เก่า" เหมือนกัน แต่อยู่ในคอลัมน์เดียวกัน หลังจากใส่โค้ดแล้ว ทั้งคอลัมน์ A จะถูกลบออกทันที
ฉันไม่แน่ใจว่าฉันเข้าใจประเด็นของคุณ คงจะดีถ้าคุณสามารถให้ภาพหน้าจอของสิ่งที่คุณพยายามทำ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดี สามารถทำได้โดยใช้ชื่อคอลัมน์หลายคอลัมน์หรือไม่
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดีมาร์ค
ลองโค้ดด้านล่าง ในบรรทัดที่แปด โปรดใส่ชื่อคอลัมน์แต่ละคอลัมน์ด้วยเครื่องหมายคำพูดคู่ และคั่นด้วยเครื่องหมายจุลภาค หวังว่าฉันจะช่วยได้ ขอขอบคุณ.

ลบย่อยSpecifcColumn()

xFNum หรี่, xFFNum, xCount เป็นจำนวนเต็ม

Dim xStr เป็นสตริง

Dim xArrName เป็นตัวแปร

Dim MR, xRg เป็นช่วง

เกี่ยวกับข้อผิดพลาดต่อไป

ตั้งค่า MR = ช่วง ("A1:N1")

xArrName = Array("old", "new", "get") 'ปิดแต่ละชื่อคอลัมน์ด้วยเครื่องหมายคำพูดคู่และคั่นด้วยเครื่องหมายจุลภาค

xCount = MR.Count

xStr = xArrName(xFNum)

สำหรับ xFFNum = xCount ถึง 1 ขั้นตอน -1

ตั้งค่า xRg = เซลล์ (1, xFFNum)

สำหรับ xFNum = 0 ถึง UBound(xArrName)

xStr = xArrName(xFNum)

ถ้า xRg.Value = xStr แล้ว xRg.EntireColumn.Delete

ถัดไป xFNum

ต่อไป

ย่อยสิ้นสุด
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ฉันคิดว่าจำเป็นต้องเปลี่ยนบรรทัดที่ 12 เพื่อให้รหัสทำงานได้ บรรทัดเดิม 12 "Set xRg = Cells (1, xFFNum)" บรรทัดที่แก้ไข 12 "Set xRg = MR (1, xFFNum)"
ลบย่อยSpecifcColumn()
xFNum หรี่, xFFNum, xCount เป็นจำนวนเต็ม
Dim xStr เป็นสตริง
Dim xArrName เป็นตัวแปร
Dim MR, xRg เป็นช่วง
เกี่ยวกับข้อผิดพลาดต่อไป
ตั้งค่า MR = ช่วง ("A1:N1")
xArrName = Array("old", "new", "get") 'ปิดแต่ละชื่อคอลัมน์ด้วยเครื่องหมายคำพูดคู่และคั่นด้วยเครื่องหมายจุลภาค
xCount = MR.Count
xStr = xArrName(xFNum)
สำหรับ xFFNum = xCount ถึง 1 ขั้นตอน -1
ตั้งค่า xRg = MR (1, xFFNum)
สำหรับ xFNum = 0 ถึง UBound(xArrName)
xStr = xArrName(xFNum)
ถ้า xRg.Value = xStr แล้ว xRg.EntireColumn.Delete
ถัดไป xFNum
ต่อไป
ย่อยสิ้นสุด
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
เกิดอะไรขึ้นถ้าส่วนหัวเริ่มจากแถวที่ 4
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ตัวอย่าง VBA ระบุว่ารหัสจะลบคอลัมน์ทั้งหมดที่มีส่วนหัวเป็น "เก่า" นั่นไม่ใช่กรณี ตัวดำเนินการ = จะลบเฉพาะรายการที่ตรงกันเท่านั้น คุณต้องใช้โอเปอเรเตอร์ LIKE กับไวด์การ์ด
รหัสถาวร: Sub DeleteSpecifcColumn()
ตั้งค่า MR = ช่วง ("A1:D1")
สำหรับแต่ละเซลล์ใน MR
ถ้า cell.Value LIKE "old*" แล้ว cell.EntireColumn.Delete
ต่อไป
ย่อยสิ้นสุด

ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดี ขอบคุณสำหรับการแก้ไขและแบ่งปันของคุณ 
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
Hola, tengo una hoja de excel ที่มี varios datos, digamos 4 คอลัมน์และ 12 filas, me gustaría poder imprimir cada fila en un folio separado en una plantilla, es decir, tenemos una hoja con varios nombres y apellidos y , como filas tenga la hoja de excel, he inte tado varias cosas pero no encuentro la forma. ทั้งหมด Gracias de antemano
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดี
ถ้าคุณต้องการพิมพ์แต่ละแถวในหน้าแยกต่างหากในเวิร์กชีต ต่อไปนี้คือคำแนะนำให้คุณแทรกตัวแบ่งหน้าทุกๆ 1 แถว แล้วพิมพ์ออกมา
วิธีการที่ระบุไว้ในบทความนี้อาจช่วยคุณได้ ได้โปรดลองดู ขอขอบคุณ.
วิธีการแทรกหน้าแบ่งทุก X แถวใน Excel?[/ url]
https://www.extendoffice.com/documents/excel/1774-excel-insert-page-break-every-row.html
มีความคิดเห็นยังไม่มีการโพสต์ที่นี่
แสดงความคิดเห็นของคุณ
โพสต์ในฐานะแขก
×
ให้คะแนนโพสต์นี้:
0   ตัวอักษร
สถานที่แนะนำ