: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

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

ฟอรัมถาม-ตอบปัญหาการใช้งาน MS Excel and VBA
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. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
pngzfoo
Member
Member
Posts: 1
Joined: Wed Nov 06, 2024 4:25 pm
Excel Ver: Microsoft office home and business 2019

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

#1

Post 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 ไว้อยู่แล้วค่ะ
สามารถแก้ไขยังไงได้บ้างเพื่อให้สามารถใช้งานได้เหมือนกันคะ
User avatar
snasui
Site Admin
Site Admin
Posts: 30905
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

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

#2

Post 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 จากเครื่องที่ใช้งานได้มาแทนไฟล์เดิม
Post Reply