snasui.com ยินดีต้อนรับ
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ ระบุ Version ของ Excel
คำแสดงเจตนา
ขอผลแห่งการให้ความรู้นี้ จงกลับไปยังผู้ที่เป็นเจ้าของเดิม แม้ข้าพเจ้าจะไม่รู้จักท่านก็ตาม ขอให้แสงแห่งปัญญาที่ท่านเคยจุดไว้ ได้กลับไปเติมเต็มชีวิตของท่านอีกครั้ง และขอให้เจตนาของข้าพเจ้าเป็นการคืนความดีอย่างสงบ
ฟอรัมถาม-ตอบปัญหาการใช้งาน MS Excel and VBA
Forum rules
ไม่อนุญาตให้ใช้ภาษาแชทในการถามและตอบปัญหา ไม่ใช้คำว่า "คับ" หรือ "อ่ะครับ" แทนคำว่า "ครับ" ไม่ใช้คำว่า "เด๋ว" แทนคำว่า "เดี๋ยว" เป็นต้น เนื่องจากเมื่อแปลเป็นภาษาต่างประเทศแล้วจะให้ความหมายผิดไปจากที่ควรจะเป็น
ห้ามถามโดยระบุชื่อผู้ตอบและต้องตั้งชื่อกระทู้ให้สื่อถึงปัญหาที่จะถาม ไม่ตั้งชื่อว่า ช่วยด้วยครับ, มีปัญหามาปรึกษาครับ เป็นต้น
กรุณาอธิบายปัญหาและระบุคำตอบที่ต้องการมาในกระทู้ด้วยเสมอถึงแม้จะอธิบายไว้ในไฟล์แนบแล้วก็ตาม ทั้งนี้เพื่ออำนวยความสะดวกแก่เพื่อนสมาชิกในการค้นหาข้อมูล
กรุณาแนบไฟล์ตัวอย่างพร้อมแสดงคำตอบที่ถูกต้องมาในไฟล์ด้วยเพื่อให้ง่ายต่อการทำความเข้าใจและสะดวกต่อการตอบคำถาม (ขนาดไฟล์ไม่เกิน 500Kb ขนาดภาพไม่เกิน 800*600 Pixel) ไม่แนบเป็น Link มาจากแหล่งอื่นที่อาจจะถูกลบทิ้งไปโดยต้นทางในภายหลัง นอกจากนี้ไม่ควรแนบไฟล์ที่มีข้อมูลสำคัญอันก่อให้เกิดความเสียหายกับตนเองและผู้อื่น
กรณีเป็นคำถามเกี่ยวกับ Programming เช่น VBA, VB.Net, C#, SQL ฯลฯ ต้องลองเขียนมาเองก่อนเสมอ ถามเฉพาะที่ติดปัญหา ระบุ Module, Procedure ที่ติดปัญหาให้ชัดเจน กรุณาโพสต์ Code ให้แสดงเป็น Code คือเปิดด้วย [code] และปิดด้วย [/code] ตัวอย่างเช่น [code]dim r as range[/code] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
pngzfoo
Member
Posts: 1 Joined: Wed Nov 06, 2024 4:25 pm
Excel Ver: Microsoft office home and business 2019
#1
Post
by pngzfoo » Wed Nov 06, 2024 4:56 pm
รบกวนสอบถามค่ะ
ปกติตอนใช้งาน VBA ที่เครื่องตัวเองจะ Import ทั้งหมด 3 ไฟล์ตามด้านล่าง แล้วจะใช้งานได้ปกติค่ะ
- allMod.bas
- clsMain.cls
- userForm.frm โดยที่ในโฟลเดอร์เดียวกันจะมีไฟล์ .frx วางอยู่ด้วย
ทีนี้ต้องการให้เครื่องอื่นใช้งานด้วยก็เลยทำแบบเดียวกัน สร้าง path file เหมือนกันทั้งหมดค่ะ แต่ขึ้นหน้าจอขึ้น
"Could not load an object because it is not available on this machine"
ตอนที่ Import ไฟล์ userForm.frm
ได้ลองตรวจสอบ Tool -> Reference แล้ว เหมือนกันทั้งเครื่องที่ใช้งานได้และเครื่องที่ขึ้น Error ดังนี้ค่ะ
- Visual Basic for Application
- Microsoft Excel 16.0 Object Library
- OLE Automation
- Microsoft Office 16.0 Object Library
- Microsoft Forms 2.0 Object Library
ตรวจสอบเครื่องที่ขึ้น Error โหลด mscomct2.ocx และ mscomctl.ocx ไว้อยู่แล้วค่ะ
สามารถแก้ไขยังไงได้บ้างเพื่อให้สามารถใช้งานได้เหมือนกันคะ
snasui
Site Admin
Posts: 31175 Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 2019
Contact:
#2
Post
by snasui » Wed Nov 06, 2024 8:05 pm
ด้านล่างนี้เป็นคำตอบจาก ChatGPT ลองทดสอบดูว่าแก้ปัญหาได้หรือไม่ครับ
ปัญหาที่คุณพบ ("Could not load an object because it is not available on this machine") น่าจะเกิดจากไฟล์หรือวัตถุ (Object) บางตัวที่ UserForm ใช้งานอยู่อาจจะไม่สามารถใช้งานได้ในเครื่องที่มีปัญหา ลองทำตามขั้นตอนนี้เพื่อแก้ไขปัญหา
ตรวจสอบ References อื่น ๆ
บางครั้ง Object ที่ UserForm ใช้งานอยู่อาจต้องอ้างอิงถึง Library อื่นที่ยังไม่ได้ติดตั้งในเครื่องนั้น แม้ว่าคุณจะตรวจสอบ References หลัก ๆ แล้ว ลองตรวจสอบ References อื่น ๆ ที่อาจจะเป็นไปได้ เช่น Library ของ ActiveX Control ที่ใช้เฉพาะบางเครื่อง หรือตัวควบคุมที่มีเฉพาะในบางเวอร์ชันของ Excel
ตรวจสอบ Object Control ใน UserForm
เปิด UserForm ที่เครื่องที่ทำงานได้ปกติแล้วตรวจสอบว่า UserForm ใช้ Control ชนิดไหนบ้าง เช่น TextBox, ComboBox, หรือ Control ที่เป็น ActiveX พิเศษที่อาจไม่ได้ติดตั้งในเครื่องอื่น หากพบว่ามี Control ที่เป็นของ ActiveX ให้ลองติดตั้งหรือรีจิสเตอร์ไฟล์ .ocx ของ Control นั้นในเครื่องที่มีปัญหา
ตรวจสอบและติดตั้งไฟล์ mscomct2.ocx และ mscomctl.ocx ใหม่
หากไฟล์ mscomct2.ocx และ mscomctl.ocx ถูกโหลดในเครื่องแล้ว แต่ยังขึ้น Error ลองทำตามขั้นตอนนี้:
ไปที่ Command Prompt แล้วรันในโหมด Administrator
ใช้คำสั่ง regsvr32 /u mscomct2.ocx เพื่อลบการรีจิสเตอร์ไฟล์นี้ แล้วตามด้วย regsvr32 mscomct2.ocx เพื่อลงทะเบียนใหม่
ทำซ้ำขั้นตอนเดิมกับ mscomctl.ocx โดยใช้คำสั่ง regsvr32 /u mscomctl.ocx และ regsvr32 mscomctl.ocx
ตรวจสอบ Compatibility ของ Excel และ Windows
บางครั้งปัญหานี้เกิดขึ้นจากความแตกต่างในเวอร์ชันของ Excel หรือ Windows ที่ใช้กันในแต่ละเครื่อง โดยเฉพาะถ้ามีการใช้งาน Control ที่ไม่รองรับในบางเวอร์ชัน
ทดสอบ Export/Import Form ใหม่
ลอง Export ไฟล์ UserForm ออกมาใหม่จากเครื่องที่ใช้งานได้ จากนั้น Import ไฟล์นั้นเข้ามาในเครื่องที่มีปัญหาอีกครั้ง เผื่อว่าไฟล์มีปัญหาหรือผิดพลาดขณะการ Import
ตรวจสอบความเข้ากันได้ของไฟล์ .frx
ไฟล์ .frx คือไฟล์ที่เก็บข้อมูลของ Form เช่น รูปภาพหรือข้อมูลเฉพาะที่ใช้กับ Control บน UserForm หาก .frx เกิดความเสียหาย อาจทำให้ Form โหลดไม่สมบูรณ์ ลองคัดลอกไฟล์ .frx จากเครื่องที่ใช้งานได้มาแทนไฟล์เดิม