Page 1 of 1

ไม่เข้าใจพื้นฐาน Function ครับ

Posted: Mon Mar 08, 2010 10:36 pm
by towhu
สวัสดีครับทุกท่าน
คือ ผมเป็นผู้ใช้งานมือใหม่ครับ

ตอนแรก มีปัญหาเรื่องต้องการหา unique name ใน column
หาคำตอบในเนต เลยได้เจอกับคำตอบของคุณคนควนครับ พยายามจะทำความเข้าใจ
แต่ไม่เข้าใจตั้งแต่การหาจำนวนของ unique name ใน column แล้วครับ

รบกวนถามดังนี้ครับ
สูตร =SUMPRODUCT((A2:A10<>"")/COUNTIF(A2:A10,A2:A10&""))

ลองแยกออกมาทดลองใช้ ก็งงกับตัวเอง เข้าใจแค่ตรง countif เองครับ ใช้แบบ array
ถ้าใช้โดยไม่ได้กด Ctrl+Shift+Enter !? แล้วมันหาทั้งแถววนไปวนมาได้ไงหว่า !?
แถมเอามาเป็นตัวหาร !?
แล้ว sumproduct นี่ถ้าเป็นแถวเดียวมันจะบวกกันเฉยๆหรือเปล่าครับ? ต่างกับ sum ยังไงครับ?

ลองค้นสูตรอื่นดูพบว่าไม่เข้าใจเหมือนกันครับ เช่น =SUM(IF(FREQUENCY(A2:A10,A2:A10)>0,1))
จะต้องมีอะไรที่เป็นความเข้าใจพื้นฐานที่ผมไม่เข้าใจแน่เลยครับ :cry:

ขออภัยที่ถามเรื่องพื้นๆครับ

Re: ไม่เข้าใจพื้นฐาน Function ครับ

Posted: Tue Mar 09, 2010 8:58 am
by snasui
:D สวัสดีครับ

สำหรับสูตรที่ถามนั้นไม่ได้เป็นสูตรพื้น ๆ ครับ เป็นสูตรที่ต้องเข้าใจหลักการทำงานของสูตรแบบ Array ซึ่งเป็นขั้นสูง
กว่าความเข้าใจแบบใช้สูตรทั่วไป

สูตร Array สามารถอ่านคร่าว ๆ ได้จากที่นี่ครับ http://www.snasui.com/viewtopic.php?f=3&t=57

Excel 2003 ลงไปฟังก์ชั่น Sumproduct สามารถมีส่วนประกอบได้ 30 ส่วนประกอบ แต่ละส่วนประกอบสามารถเป็น Array หรือช่วง
ข้อมูล ผลลัพธ์ของฟังก์ชั่นมาจากนำแต่ละส่วนประกอบมาคูณกันครับ เช่น

=Sumproduct({1,2,3},{4,5,6})

การคำนวณของฟังก์ชั่นจะเป็นดังนี้คือ 1*4+2*5+3*6 สำหรับ {1,2,3} และ {4,5,6} สามารถใช้ช่วงข้อมูล เช่น
=Sumproduct(A1:A3,B1:B3) แทนได้

ส่วนสูตร Countif ที่นำมาใช้ใน Sumproduct ก็ไม่ได้ใช้อย่าง Countif ทั่ว ๆ ไปครับ หลักการทำงานสามารถดู
ได้ตามภาพแสดงการ Evaluate สูตรด้านล่าง ซึ่งเป็นการใช้ F9 ในการแกะสูตร

สิ่งสำคัญอีกประการหนึ่งคือ Array ที่เป็นการเปรียบเทียบจะให้ผลลัพธ์เป็น True หรือ False และ True หรือ
False นี้คือ 1 และ 0 ตามลำดับ แต่จะเป็น 1 และ 0 ได้ก็ต่อเมื่อมีตัวดำเนินการมากระทำ เช่น บวก ลบ คูณ หาร
ยกกำลัง เป็นต้น ดังจะเห็นว่าผมใช้การแปลง True, False เป็น 1, 0 ด้วยการใช้เครื่องหมาย -- หรือ +0

สำหรับสูตรที่ถามมานี้ไม่ต้องใช้ตัวดำเนินการเพิ่มเติมอื่นใดอีก ทั้งนี้เพราะว่ามีตัวดำเนินการคือเครื่องหมายหารมาพร้อมในสูตรแล้วซึ่งจะบังคับให้ True, False เป็น 1, 0 อยู่ในตัว

ดูภาพการแกะสูตรตามด้านล่างครับ :mrgreen:

Re: ไม่เข้าใจพื้นฐาน Function ครับ

Posted: Tue Mar 09, 2010 10:30 am
by towhu
ชัดเจนครับ

ได้ความรู้เพิ่มเยอะเลย :D
- ถ้าอยู่ในสูตร คำตอบเป็น Array ได้ด้วย
- การใช้ True, False ซ้ำ5ตัวหาร5 ซ้ำเท่าไหร่หารเท่านั้น บวกกันได้ 1 คิดได้ไงอะครับ :o
- F9!!

ขอบคุณครับ