: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
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. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#1

Post by Remnant »

http://image.ohozaa.com/i/g96/WWLXry.jpg

จากรูปตัวอย่างในเซลล์ K6 ผมใส่สูตรว่า

=IF(F6=$E$2,$E$3,IF(F6=$F$2,$F$3,IF(F6=$G$2,$G$3,IF(F6=$H$2,$H$3,IF(F6=$I$2,$I$3,IF(F6=$J$2,$J$3,IF(F6=$K$2,$K$3,IF(F6=$L$2,$L$3,IF(F6=$M$2,$M$3,$N$3)))))))))-IF(F6=B6,1,0)-IF(F6=C6,1,0)-IF(F6=D6,1,0)-IF(F6=E6,1,0)

ซึ่งผลลัพธ์ที่ได้จะเท่ากับ 4 - 1 = 3 ซึ่งผมอยากจะแทนที่สูตรตรงนี้ให้เปลี่ยนเป็น

= $M$3 - 1

พอจะมีวิธีการใด ทำได้บ้างครับ
You do not have the required permissions to view the files attached to this post.
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#2

Post by Remnant »

ผมลองอ่าน Help ดูแล้ว มันบอกให้กด F9 ซึ่งผมลองกดแล้ว มันจะได้ผลของค่านั้นมาให้เลย

แต่ความต้องการของผมคืออยากให้มันแทนที่ด้วยผลลัพธ์ที่เป็นสูตรมากกว่าครับ

ขอบคุณครับ
User avatar
bank9597
Guru
Guru
Posts: 3868
Joined: Wed Aug 17, 2011 11:49 am

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#3

Post by bank9597 »

:D ที G6 คีย์ =INDEX($E$3:$N$3,MATCH(B6,$E$2:$N$2,0)) คัดลอกสูตรไปขวามือ แล้วลงล่างพร้อมกัน

นอกนั้นก็ใส่เงื่อนไขเพิ่มเติมที่เหลือครับ
Forum Rules
  1. อย่าใช้ภาษาแชทในการตอบ-ถาม
  2. ตั้งชื่อกระทู้ให้สื่อถึงปัญหาและไม่เจาะจงตัวผู้ตอบ
  3. ให้อธิบายปัญหาและระบุคำตอบที่ต้องการมาในฟอรัม
  4. ควรแนบไฟล์ตัวอย่างมาที่ฟอรั่ม
  5. หากใช้ VBA ให้ลองเขียนมาเองก่อนเสมอ
  6. แจ้งผลการใช้งานทุกครั้งเมื่อได้รับคำตอบ
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#4

Post by Remnant »

bank9597 wrote::D ที G6 คีย์ =INDEX($E$3:$N$3,MATCH(B6,$E$2:$N$2,0)) คัดลอกสูตรไปขวามือ แล้วลงล่างพร้อมกัน

นอกนั้นก็ใส่เงื่อนไขเพิ่มเติมที่เหลือครับ
ขอบคุณครับ วิธีนี้ ลดความยาวสูตรได้เยอะเลยครับ ผมไม่เคยใช้ MATCH เลย

แต่จำนวนเซลล์ที่ผมทำมันเป็นแสนบรรทัดเลยครับ มีวิธีอื่นแนะนำอีกมั้ยครับ

แบบช่อง G6 อยากให้มันมีค่า = $M$3 เลยอ่ะครับ

ขอบคุณอีกรอบครับ
User avatar
bank9597
Guru
Guru
Posts: 3868
Joined: Wed Aug 17, 2011 11:49 am

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#5

Post by bank9597 »

:ugeek: ยังไงก็ต้องใช้สูตรดึงมาอยู่ดีครับ จะให้เอาค่าใน M3 มาวางดื้อๆแบบนั้นคงไม่ได้ครับ

อีกทั้งโจทย์ที่บอกไว้ก็ไม่ชัดเจนว่าต้องการทำอะไร มีเงื่อนไขอย่างไร
Forum Rules
  1. อย่าใช้ภาษาแชทในการตอบ-ถาม
  2. ตั้งชื่อกระทู้ให้สื่อถึงปัญหาและไม่เจาะจงตัวผู้ตอบ
  3. ให้อธิบายปัญหาและระบุคำตอบที่ต้องการมาในฟอรัม
  4. ควรแนบไฟล์ตัวอย่างมาที่ฟอรั่ม
  5. หากใช้ VBA ให้ลองเขียนมาเองก่อนเสมอ
  6. แจ้งผลการใช้งานทุกครั้งเมื่อได้รับคำตอบ
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#6

Post by Remnant »

ประมาณแบบนี้ครับ สูตรเดิมที่ K6 คือ

=IF(F6=$E$2,$E$3,IF(F6=$F$2,$F$3,IF(F6=$G$2,$G$3,IF(F6=$H$2,$H$3,IF(F6=$I$2,$I$3,IF(F6=$J$2,$J$3,IF(F6=$K$2,$K$3,IF(F6=$L$2,$L$3,IF(F6=$M$2,$M$3,$N$3)))))))))-IF(F6=B6,1,0)-IF(F6=C6,1,0)-IF(F6=D6,1,0)-IF(F6=E6,1,0)

เมื่อสูตรตรวจสอบเงื่อนไขแล้ว จะไปตรงเงื่อนไขช่อง $M$3 แล้วก็ตรวจสอบเงื่อนไขด้านหลังที่ผมเขียนไว้คือ ถ้าตัวเลขซ้ำกับด้านหน้า 1 ตัวก็ให้ลบ 1 ถ้าซ้ำ 2 ตัวก็ให้มีค่าลบเท่ากับ 2 คือมันเป็นสูตรความน่าจะเป็นอ่ะครับ

เช่นถ้า สุ่มหยิบตัวเลขมา 5 ตัว ได้เลข 9 ทั้ง 5 ตัว

ผมอยากให้มันแทนที่ด้วยสูตรดังนี้ครับ

ช่อง G6 =$M$3
ช่อง H6 =$M$3 - 1
ช่อง I6 =$M$3 - 2
ช่อง J6 =$M$3 - 3
ช่อง K6 =$M$3 - 4

ค่าลบด้านหลัง ผมพอจะคิดออกแล้วว่าจะทำยังไงครับ
ตอนนี้ติดแต่ตัวแรกครับ ทำยังไง จะสามารถแทนกันได้เลย
ถ้าทำได้ จะสามารถลดเนื่อที่ได้เยอะเลยครับ

ขอบคุณครับ
User avatar
bank9597
Guru
Guru
Posts: 3868
Joined: Wed Aug 17, 2011 11:49 am

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#7

Post by bank9597 »

ที G6 คีย์ =INDEX($E$3:$N$3,MATCH(B6,$E$2:$N$2,0)) คัดลอกสูตรไปขวามือ แล้วลงล่างพร้อมกัน
ผมได้ตอบสูตรการดึงค่า E3:N3 แล้วด้านบน :aru:

ส่วนเงื่อนไขที่เหลือ จะให้ลบอะไรยังไง คุณก็ใช้สูตรเดิมของคุณ :ard:
นอกนั้นก็ใส่เงื่อนไขเพิ่มเติมที่เหลือครับ
Forum Rules
  1. อย่าใช้ภาษาแชทในการตอบ-ถาม
  2. ตั้งชื่อกระทู้ให้สื่อถึงปัญหาและไม่เจาะจงตัวผู้ตอบ
  3. ให้อธิบายปัญหาและระบุคำตอบที่ต้องการมาในฟอรัม
  4. ควรแนบไฟล์ตัวอย่างมาที่ฟอรั่ม
  5. หากใช้ VBA ให้ลองเขียนมาเองก่อนเสมอ
  6. แจ้งผลการใช้งานทุกครั้งเมื่อได้รับคำตอบ
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#8

Post by Remnant »

คำตอบที่ผมต้องการ ผมได้แนบไฟล์ตัวอย่างมาแล้วครับ

อยากให้เป็นแบบช่อง G6:H15 อ่ะครับ

แล้วมันจะทำให้สามารถลบข้อมูลช่อง B6:C15 ออกได้เลยอ่ะครับ

ผมอยากทราบจริงๆ ว่า Excel สามารถทำตรงนี้ได้หรือเปล่าครับ

ขออภัยด้วยครับ ที่รบกวนถามเยอะ

ขอบคุณครับ
You do not have the required permissions to view the files attached to this post.
User avatar
bank9597
Guru
Guru
Posts: 3868
Joined: Wed Aug 17, 2011 11:49 am

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#9

Post by bank9597 »

ที่ G6 คีย์ =INDEX($E$3:$N$3,MATCH(B6,$E$2:$N$2,0)) คัดลอกไปที่ H6 แล้วคัดลอกสูตรลงมาพร้อมกัน ทั้ง G6 และ H6

ที่ I6 คีย์ =INDEX($E$3:$N$3,MATCH(D6,$E$2:$N$2,0))-(COUNTIF($B6:D6,D6)-1) คัดลอกไปที่ K6 แล้วคัดลอกลงมาพร้อมกัน
You do not have the required permissions to view the files attached to this post.
Forum Rules
  1. อย่าใช้ภาษาแชทในการตอบ-ถาม
  2. ตั้งชื่อกระทู้ให้สื่อถึงปัญหาและไม่เจาะจงตัวผู้ตอบ
  3. ให้อธิบายปัญหาและระบุคำตอบที่ต้องการมาในฟอรัม
  4. ควรแนบไฟล์ตัวอย่างมาที่ฟอรั่ม
  5. หากใช้ VBA ให้ลองเขียนมาเองก่อนเสมอ
  6. แจ้งผลการใช้งานทุกครั้งเมื่อได้รับคำตอบ
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#10

Post by Remnant »

bank9597 wrote:ที่ G6 คีย์ =INDEX($E$3:$N$3,MATCH(B6,$E$2:$N$2,0)) คัดลอกไปที่ H6 แล้วคัดลอกสูตรลงมาพร้อมกัน ทั้ง G6 และ H6

ที่ I6 คีย์ =INDEX($E$3:$N$3,MATCH(D6,$E$2:$N$2,0))-(COUNTIF($B6:D6,D6)-1) คัดลอกไปที่ K6 แล้วคัดลอกลงมาพร้อมกัน
ยังไม่ตรงกับคำตอบที่ผมอยากทราบครับ แต่ขอบคุณมากๆ เลยครับ ผมได้ความรู้มากขึ้น คือลดความยาวสูตรได้เยอะเลย

ซึ่งผมคิดไม่ถึงเรื่อง COUNTIF เลยว่าใช้แทนได้ พิมพ์ซะมือหงิกเลย
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#11

Post by Remnant »

http://image.ohozaa.com/i/g9f/UKaNNL.jpg

ตอนนี้ผมได้แก้ไข โดยการใส่สูตร ให้มันแสดงเป็นข้อความแทน จากนั้นผมก็กด Copy

แล้ว Paste Special > Value ก็จะเหลือแต่ Text ตามรูปครับ

จากนั้นผมก็ต้องไปไล่กดในสูตร แล้ว Enter จึงจะได้คำตอบตามที่ต้องการครับ

แต่ประเด็นคือไล่กดทีละบรรทัดจนครบแสนบรรทัดคงไม่ไหวครับ

มีวิธีการอะไร ที่จะเปลี่ยน Text ให้เป็นสูตรบ้างครับ

ขอบคุณครับ
User avatar
snasui
Site Admin
Site Admin
Posts: 31257
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#12

Post by snasui »

:D รูปหรือไฟล์แนบทีใช้ประกอบคำถามควรจะแนบมาที่ฟอรัมนี้ ยกเว้นเป็นการตอบคำถามผมจะได้ช่วยดูได้ครับ
Remnant
Member
Member
Posts: 42
Joined: Mon Feb 17, 2014 9:50 pm
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#13

Post by Remnant »

snasui wrote::D รูปหรือไฟล์แนบทีใช้ประกอบคำถามควรจะแนบมาที่ฟอรัมนี้ ยกเว้นเป็นการตอบคำถามผมจะได้ช่วยดูได้ครับ
รูปอยู่ในลิ้งค์ครับ เพราะผมพยายามแนบแล้ว มันไม่แสดงผลครับ

ขอบคุณครับ
User avatar
snasui
Site Admin
Site Admin
Posts: 31257
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:

Re: สอบถามเรื่องการแทนที่สูตร ด้วยสูตรที่คำนวณได้

#14

Post by snasui »

:lol: อย่าเข้าใจว่าผมไม่ทราบว่าจะไปดูภาพได้อย่างไรครับ สำหรับไฟล์ประกอบคำถามผมเจตนาจะให้แนบภาพมาในฟอรัมนี้เท่านั้น เพราะจะได้ไม่มีปัญหาหากเว็บที่รับฝากไฟล์ได้ลบภาพนั้นทิ้งไป

วิธีการแนบภาพแนบไฟล์ดูที่ Link นี้ครับ ไฟล์ต้องมีขนาดไม่เกิน 300kb ครับ :arrow: viewtopic.php?f=3&t=46
Post Reply