Page 1 of 1

error "Could not load an object because it is not available on this machine" ตอน Import file userForm

Posted: Wed Nov 06, 2024 4:56 pm
by pngzfoo
รบกวนสอบถามค่ะ
ปกติตอนใช้งาน 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 ไว้อยู่แล้วค่ะ
สามารถแก้ไขยังไงได้บ้างเพื่อให้สามารถใช้งานได้เหมือนกันคะ

Re: error "Could not load an object because it is not available on this machine" ตอน Import file userForm

Posted: Wed Nov 06, 2024 8:05 pm
by snasui
:D ด้านล่างนี้เป็นคำตอบจาก ChatGPT ลองทดสอบดูว่าแก้ปัญหาได้หรือไม่ครับ

ปัญหาที่คุณพบ ("Could not load an object because it is not available on this machine") น่าจะเกิดจากไฟล์หรือวัตถุ (Object) บางตัวที่ UserForm ใช้งานอยู่อาจจะไม่สามารถใช้งานได้ในเครื่องที่มีปัญหา ลองทำตามขั้นตอนนี้เพื่อแก้ไขปัญหา
  1. ตรวจสอบ References อื่น ๆ
    บางครั้ง Object ที่ UserForm ใช้งานอยู่อาจต้องอ้างอิงถึง Library อื่นที่ยังไม่ได้ติดตั้งในเครื่องนั้น แม้ว่าคุณจะตรวจสอบ References หลัก ๆ แล้ว ลองตรวจสอบ References อื่น ๆ ที่อาจจะเป็นไปได้ เช่น Library ของ ActiveX Control ที่ใช้เฉพาะบางเครื่อง หรือตัวควบคุมที่มีเฉพาะในบางเวอร์ชันของ Excel
  2. ตรวจสอบ Object Control ใน UserForm
    เปิด UserForm ที่เครื่องที่ทำงานได้ปกติแล้วตรวจสอบว่า UserForm ใช้ Control ชนิดไหนบ้าง เช่น TextBox, ComboBox, หรือ Control ที่เป็น ActiveX พิเศษที่อาจไม่ได้ติดตั้งในเครื่องอื่น หากพบว่ามี Control ที่เป็นของ ActiveX ให้ลองติดตั้งหรือรีจิสเตอร์ไฟล์ .ocx ของ Control นั้นในเครื่องที่มีปัญหา
  3. ตรวจสอบและติดตั้งไฟล์ 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
  4. ตรวจสอบ Compatibility ของ Excel และ Windows
    บางครั้งปัญหานี้เกิดขึ้นจากความแตกต่างในเวอร์ชันของ Excel หรือ Windows ที่ใช้กันในแต่ละเครื่อง โดยเฉพาะถ้ามีการใช้งาน Control ที่ไม่รองรับในบางเวอร์ชัน
  5. ทดสอบ Export/Import Form ใหม่
    ลอง Export ไฟล์ UserForm ออกมาใหม่จากเครื่องที่ใช้งานได้ จากนั้น Import ไฟล์นั้นเข้ามาในเครื่องที่มีปัญหาอีกครั้ง เผื่อว่าไฟล์มีปัญหาหรือผิดพลาดขณะการ Import
  6. ตรวจสอบความเข้ากันได้ของไฟล์ .frx
    ไฟล์ .frx คือไฟล์ที่เก็บข้อมูลของ Form เช่น รูปภาพหรือข้อมูลเฉพาะที่ใช้กับ Control บน UserForm หาก .frx เกิดความเสียหาย อาจทำให้ Form โหลดไม่สมบูรณ์ ลองคัดลอกไฟล์ .frx จากเครื่องที่ใช้งานได้มาแทนไฟล์เดิม