: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

ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

ฟอรัมถาม-ตอบปัญหาการใช้งาน 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. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
hellish
Member
Member
Posts: 6
Joined: Fri Sep 24, 2010 10:42 pm

ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

#1

Post by hellish »

คนควนครับ
ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ
โดยพื้นที่ต้องการวางสูตรจะไม่มี row ที่ตายตัว
แต่จะมี column คงที่
ตัวอย่างความต้องการอยู่ใน file แนบครับ (งานจริงที่ใช้จะประมาณ 4-5 พัน rowไม่กล้าส่งให้ครับคือมันใหญ่มากก)
ขอบคุณครับ
ปล.ตอนนี้กำลังปั่นข้อมูลอยู่ครับเนื่องจาก server ที่ใช้งานป่วยกระทันหัน
hellish.
You do not have the required permissions to view the files attached to this post.
User avatar
snasui
Site Admin
Site Admin
Posts: 30944
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

Re: ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

#2

Post by snasui »

:D การทำแบบนั้นไม่ต้องใช้ Macro ก็ทำได้ครับ

ลองตามนี้ครับ

1. คีย์สูตรที่ X2

=IF(ISTEXT($K5),O5,LOOKUP(9.99999999999999E+307,O$5:O5)*$K5/1000)

Enter > Copy ไปถึง AF2 > จากนั้น Copy ไปด้านล่าง > จากนั้นค่อย Copy ข้อมูลที่ได้นี้ให้เป็น Value

ดูตัวอย่างตามไฟล์แนบครับ :mrgreen:
You do not have the required permissions to view the files attached to this post.
hellish
Member
Member
Posts: 6
Joined: Fri Sep 24, 2010 10:42 pm

Re: ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

#3

Post by hellish »

ขอบคุณครับ
เอ่อ ค่อนข้างจำเป็นครับ
เนื่องจากรหัสที่ใช้จะถูกเปลี่ยนไปเรื่อยๆ ไม่ค่อยซ้ำ แต่ที่ซ้ำคือรูปแบบการคำนวนครับ
ส่วนค่าใน column K ก็จะได้มาจากการคำนวนของอีก file นึงครับ
คือพยายามจะเลี่ยงการวางสูตรใน cell ของทุกกลุ่มรหัสย่อย ทั้งหมด 5พันกว่ารหัส
เพราะ excel มันจะช้ามากกก
(กำหนดแบบ manual แล้วครับ) ตอนนี้กำลังทดลองวางทีละชุด ชุดละ 5 รหัส
พอได้ผลลัพท์ ก็ ย้ายไปอีกชีทที่เป็นตัวรับข้อมูลครับ
ถ้างั้นผมขออนุญาติ เอาคำสั่งชุดนี้ไปแปลงเป็นแมโครนะครับ
ขอบคุณมากครับพ้ม
hellish
Member
Member
Posts: 6
Joined: Fri Sep 24, 2010 10:42 pm

Re: ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

#4

Post by hellish »

รบกวนอีกนิดครับ
นอกจากคำสั่งชุดนี้
With Application
.Calculation = xlManual
.MaxChange = 0.001
End With
ActiveWorkbook.PrecisionAsDisplayed = False
มีวิธีใดอีกครับที่ให้ excel ทำงานเร็วขึ้นครับ
ขอบคุณครับ
User avatar
snasui
Site Admin
Site Admin
Posts: 30944
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

Re: ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

#5

Post by snasui »

:D การกำหนดให้ Excel ทำการคำนวณแบบ Manual สามารถใช้คำสั่งตามด้านล่างได้ครับ

application.calculation = xlmanual

กรณีไฟล์คำนวณช้าต้องดูหลายอย่างประกอบ ทั้ง Hardware และ Software ครับ หากไม่มีปัญหาเรื่อง Hardware (หลัก ๆ คือ CPU, Ram) ก็ต้องมาดูว่าไฟล์มีการคำนวณอย่างไร ใช้ัฟังก์ชั่นประเภทใด เป็น Volatile ฟังก์ชั่นหรือไม่ หรือใช้ฟังก์ชั่น Lookup แบบตรงตัวเยอะมากมายขนาดไหน ใช้ List หรือไม่ ให้ชื่อไว้กับช่วงข้อมูลจำนวนมากหรือไม่ มีการเชื่อมโยงข้อมูลจากไฟล์อื่นจำนวนมากหรือไม่

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

อีกทางเลือกก็ใช้ Code คำนวณแล้ววางค่าที่ได้จากการคำนวณให้เลย อันนี้น่าจะเร็วกว่าการวางสูตรแล้วค่อยแปลงกลับมาเป็น Value ต้องลองทดสอบดูครับ

Note: Volatile Function คือฟังก์ชั่นที่กระตุ้นให้เกิดการคำนวณทุกครั้งที่มีการเปลี่ยนแปลงเซลล์ แม้เซลล์นั้นไม่เกี่ยวข้องกับพื้นที่ที่ทำงาน เช่น Now(), Today(), Row, Column ฯลฯ
hellish
Member
Member
Posts: 6
Joined: Fri Sep 24, 2010 10:42 pm

Re: ขอรบกวนการเขียนคำสั่งคัดลอกและวางแบบวนลูปครับ

#6

Post by hellish »

ตัดส่วนอื่นๆ ออกไปแล้ว เหตุที่ช้าจะมาจากฐานข้อมูลอ้างอิงที่ข้ามชีทกัน คงต้องปรับวิธีทำงานตามข้อมูลอีกแล้วครับพี่น้อง
ขอบคุณสำหรับคำตอบครับ ได้แนวคิดเพิ่มมาอีก 1 วิธีแล๊ะ
1.เลือก code
2.วางจำนวนที่ต้องการ
3.เลือกชุดข้อมูลที่ใช้ประกอบ
4.คำนวน (ใช้คำตอบข้างบนไปแอบแปลงทำชุดคำสั่งเรียบร้อยแล้ว)
5.วาง
กลับไปทำ 1 - 5 จนกว่าจะครบทุก code
6.จัดกลุ่ม
7.ส่งงาน เย้ๆๆ ((ข้อ2-7 กำลังอยู่ในฝันอยู่ครับ))

ถ้าผมคิดอะไรไม่ออกอีก ผมจะแวะมาใหม่ครับ ขอบคุณอีกครั้งครับ
**ข้อจำกัด user ต้องการดูรวม 1 - 31 วัน จำนวน code 300 กว่าๆ ส่วนประกอบของแต่ละ code เฉลี่ยที่ 15-20 รายการ**
Post Reply