[Report] Logic ผิด หรือเราไม่รู้ การทำงานของมัน

วันนี้ได้ไปช่วยพี่ที่ทำงานมา ซึ่งตัวรายงานมี Layout ดังนี้ (ขอเบลอรูปนิดนึง 55) โดยโจทย์มีอยู่ว่า ชื่อของรายงาน @ReportName(หมายเลข 1 ในรูป) ขึ้นอยู่ผลรวม(SUM) ของ field #SumNetAmountGrandTotal(หมายเลข 2 ในรูป) โดยมีเงื่อนไข ดังนี้ ซึ่งในตัว Crystal Report เราสามารถเขียน formula เพื่อกำหนดการแสดงผลได้ ดังนี้ แต่เมื่อลองรัน Application และแสดงรายงานดูปรากฏว่า เงื่อนไขที่ได้กำหนดไว้ ไม่ทำงาน แล้วสาเหตุ คือ อะไร ? ลองกลับมาดูการทำงานของ Report กัน ตัว Crystal Report มีการ Render เหมือน Printer หรือถ้าในภาษาขอ Programming คือ Interpreter นี้แหละ เมื่อเรารู้ Consept การทำงานของการสร้าง Report แล้ว วกกลับมาดูที่ Layout ของ Report พบว่าส่วนของ @ReportName(หมายเลข 1 ในรูป) ถูกทำงานก่อนที่ระบบหาค่า #SumNetAmountGrandTotal(หมายเลข 2 ในรูป) ที่ถูกรวม (SUM) ก่อนอีก ? รู้สาเหตุแล้ว แก้ปัญหาอย่างไร ? เมื่อเข้าใจการทำงานของ Report ที่ทำงานจากบนลงล่างแบบ printer ดังนั้น วิธีแก้ คือ ต้องหาผลรวม(SUM) field #SumNetAmountGrandTotal ก่อนเข้าเงื่อนไข โดยแก้ไข formula ดังนี้ หมายเหตุ: จริงๆวิธีแก้ไขกับปัญหานี้มีได้หลายแบบ แต่ที่ผู้เขียนได้ยกตัวอย่างมา เพื่อให้ผู้อ่านได้เข้าใจ Consept การทำงานของ Report Writer แบบต่างๆ ซึ่งไม่จำเป็นต้องเป็น Crystal Report อย่างเดียวครับ…

Neural Network with WEKA [Verified Model]

หลังจากได้ Model มาแล้วสิ่งที่เราต้องทำต่อไป คือ การนำโมเดลที่ได้นั้นมาตรวจสอบความถูกต้อง และนำไปผลที่ได้ไปปรับแต่ง Model ของเราจนได้ผลลัพธ์ออกมาเป็นที่น่าพอใจแล้วนำไปทดสอบกับข้อมูลจริงๆ การ Verified Model ที่ได้มานั้นมีขั้นตอน ดังนี้ การทำ Neural Network คือ การ Generate and test หรือ tried and error ซึ่งหมายถึง การลองผิดลองถูก จนกว่าจะได้เป้าหมายตรงตามต้องการ และท้ายที่สุดผมหวังว่าข้อมูลชุดนี้จะเป็นประโยชน์ในการทำความเข้าใจกับโปรแกรม WEKA มากขึ้น และผมแนบวิดีโอสรุปการทำมาด้วยครับ แต่อาจจะมีจุดที่แตกในเรื่องของชุดข้อมูลที่ผมแบ่งไว้นะครับ (เสียงช่วง 1 นาทีแรกอาจจะมีเสียงแทรกนะครับ เพราะผมไม่เก่งในการตัดต่อวิดีโอ ^__^) และ Blog ถัดไปจะเป็นการสรุปปัญหาต่างๆในทางเทคนิคของโปรแกรม WEKA กับการทำ Neural Network

[SQLite] System.Data.SQLite.SQLiteConnection cannot be cast to …

C# Logo

เวันนี้เขียนโปรแกรม C# กับ SQLite อยู่ดีๆ Bulid ผ่านะ แต่ Runtime Error โดยมี Message แจ้ง ดังนี้ [A]System.Data.SQLite.SQLiteConnection cannot be cast to [B]System.Data.SQLite.SQLiteConnection. Type A originates from ‘System.Data.SQLite, Version=1.0.92.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139’ in the context ‘Default’ at location ‘C:\Users\Chatr_000\Desktop\InvConfig(AutoRegisDLL)\InvConfig\bin\Release\System.Data.SQLite.dll’. Type B originates from ‘System.Data.SQLite, Version=1.0.91.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139’ in the context ‘Default’ at location ‘C:\Windows\Microsoft.Net\assembly\GAC_32\System.Data.SQLite\v4.0_1.0.91.0__db937bc2d44ff139\System.Data.SQLite.dll’. หลังจากไล่ Code อยู่นานพบว่าในเครื่องที่ใช้ Dev มี SQLite อยู่ 2 Version คือ 1.0.91.0 กับ 1.0.92.0 ติดตั้งอยู่ ซึ่งผมได้แก้ไขโดย ถอนการติดตั้ง SQLite Version 1.0.91.0 ออกไป ซึ่งการอัพเกรด Version ของ SQLite DLL ควรทำการ Uninstall Version แก่ก่อนลง Version ใหม่เสมอ ครับ ถ้าไม่เอาออก Registry ของ Windows มันจะมองเป็น 2 Version แก้ไขการโปรแกรมใหม่ ทั้งใน app config และ Reference ของ Project ให้ Reference ไปยังไฟล์…

[JAVA] Abstract คือ อะไร และต่างกับ Interface อย่างไร

หลายๆคนคงสงสัยว่า Keyword Abstract มัน คือ อะไร และเมื่อไหร่ที่ควรจะใช้ วันนี้ผมมีตัวอย่างง่ายๆในการอธิบายนะครับ โดยอาจจะแทรกเนื้อหาเกี่ยวกับ interface เพิ่มเข้าไปด้วยครับ เพราะลายคนสับสนกันเยอะ  โดยผมขอเริ่มโจทย์ที่เราต้องใช้ Abstract Class ดังนี้ จงเขียน class Student ซึ่งประกอบด้วย data members ดังนี้ name (ชื่อนิสิต), test (อะเรย์ของคะแนน), NUM_OF_TESTS (ค่าคงที่เป็นจำนวนของ test) และ courseGrade (เกรดของวิชา) ให้สร้าง Constructor, methods get/set และ abstract method computeCourseGrade โดยมีวิธีการคำนวณต่างกันไปสำหรับนิสิตปริญญาตรี (UndergraduateStudent) และบัณฑิตศึกษา (GraduateStudent)ให้เขียน class UndergraduateStudent ซึ่งเป็น subclass ของ Student และ ทำการ implement method computeCourseGrade ตามเกณฑ์ต่อไปนี้คือ ถ้าคะแนนเฉลี่ย >= 70 ผ่าน (Pass) ถ้าคะแนนเฉลี่ย < 70 ไม่ผ่าน (Fail) ก่อนที่จะทำโจทย์ ผมอยากให้รู้จักคำศัพท์บางตัวก่อน 📌 Signature ของ Method คือ อะไร การกำหนดลักษณะของ Method name(ชื่อ method) + Parameter List(ตัวแปรที่จะส่งเข้าไป) 📌 Method Header คือ อะไร พูดง่ายๆ คือ Signature หรือการประกาศ Method ว่ามีซื่ออะไร รับอะไรมาบ้าง ส่วน Logic การทำงานของมันจะไปอยู่ใน Method Detail จ้า ดูตามรูปเลย…

[C#] แสดง Bullet (ฺจุดลิสต์รายการ) ในโปรแกรมของเราได้อย่างไร

C# Logo

เมื่อเราพัฒนาระบบขึ้นมา ระบบต้องมีการโต้ตอบ หรือให้ข้อมูลต่างๆแก่ user ซึ่งถ้าเราแสดงตัวอักษรอย่างเดียวไป มันอาจจะทำให้อ่านยาก และไม่สวยงามด้วย วันนี้ผมมานำเสนอการพิมพ์ Bullet หรือจุดลิสต์รายการ เพื่อให้ข้อมูลแสดงออกมาให้ดูง่าย ดังนี้ ก่อนอีกเลย เราต้องรู้ว่าอักษร Bullet หรือ จุดนี่ มันมีค่า Unicode ค่าอะไร เมื่อประกาศค่าคงที่เรียบร้อยแล้ว เราสามารถนำใส่ต่อกับ String ที่ต้องการได้เลยครับ อันนี้ผมนำไปใช้เพื่อแสดงรายละเอียดการแก้ไขโปรแกรม หรือ change log ให้ดูได้ง่ายขึ้นนะครับ ตัวอย่างเมื่อ Run Program ครับ

ลดทุน ลดหุ้น แล้วได้อะไร ?

จากบทความที่แล้วที่ผมได้เขียนไปเกี่ยวกับ การ ลด Par ล้างหนี้ แล้วยังติดประเด็นว่า ถ้าเราไม่ลด Par มันจะเกิดอะไรขึ้น ? ก่อนอื่นเลยต้องถึงสมการนึงก่อน ทุนจดทะเบียน(ทุน) / จำนวนหุ้น = ราคา Par ถ้าเราลดราคา Par แล้วทุนจดทะเบียนลดลง แต่จำนวนหุ้นเท่าเดิม ถ้าเรามองกลับกัน ลดทุนจดทะเบียน แต่ไม่ลดราคา Par ดังนั้นจำนวนหุ้นลดลง แล้วจำนวนหุ้นที่ลดลง มันมีผลอะไรบ้าง ? อย่างแรกเลย คือ จำนวนหุ้นที่ลดลง แต่ราคาของหุ้นจะต้องเพิ่มขึ้นตามสัดส่วนที่ได้ลดลง ผู้อ่านอาจะงงเดียวผมของยกตัวอย่างเลยนะครับบริษัท ก มีทุนจดทะเบียน 1,000 บาท โดยแบ่งจำนวนหุ้น 10,000 หุ้น ตอนนี้ราคา Par = 0.10 บาทต่อหุ้นต่อมาอีก 1 ปี บริษัท ก ทำธุรกิจขาดทุนไป 500 บาททางผู้บริษัทเลยมีมิติลดทุนเพื่อล้างหนี้ที่ขาดทุนไป โดยไม่ลดราคา Par สังเกตุว่าราคา Par มันน้อยจดลดอีกไม่ได้แล้ว 1,000 – 5000(ทุน) / 0.10(ราคา Par) = 5,000 จำนวนหุ้น เมื่อเทียบจำนวนหุ้นเดิม ต่อ จำนวนหุ้นใหม่ คือ 10,000 : 5,000 ซึ่งถ้าเทียบเป็นอัตราส่วนแล้ว คือ 2 : 1 ตีความได้ว่า 2 หุ้นเดิม จะลดเหลือ 1 หุ้นโดยมีผลให้ราคาหุ้นเพิ่มขึ้น 2 เท่า ราคาหุ้น ไม่ใช่ราคา Par นะ ถ้าราคาหุ้นเดิม คือ 1 บาท เมื่อลดทุนแล้วราคาหุ้น จะเป็น 2 บาท โดยกระบวนการที่จัดการกับส่วนนี้จะเรียกว่า…