Есть файл, работающий уже лет 7. На странице кнопка, при открытии проверяется контрольное поле и в зависимости от этого кнопка активна или нет (.Enable=True or False). Файл работал в нескольких версиях оффиса. Последнее время на 2010 и 2013 (основная версия). В результате последнего апдейта оффиса стало появляться сообщение, приведенное в описании темы. Кроме того, ранее в режиме конструктора можно было просмотреть свойства объекта (кнопки, к примеру) на листе, теперь же вызываются свойства листа, содержащего объект.
Проверил на соседней машине, оффис 2010 СП2 без последних апдейтов — все ОК. Выполнил обновление — картина та же, что описана выше…
Кто-нить сталкивался с подобной проблемой? Спасибо!
ЗЫ: Кстати, подобную проблему нашел в архиве за 2012, но на ХР у меня не возникало подобных ошибок…
http://www.planetaexcel.ru/forum/?PAGE_NAME=read&FID=8&TID=42275
First of all, you should know, that some of functions, used on the worksheet, have limitations. So my point is avoid of using them in VBA, if it is not necessary.
For example, function POWER()
returns error on attempt to raise a zero to zero. An alternative is to use 0 ^ 0
combination, which is exactly doing the same, but looks more simply and operates without such error.
But also there is no embedded alternative in VBA to the FACT()
function, so you can use it, or simply add your own function factor()
— it’s uppon your choise.
If you just have started learning VBA, I would recomend you to use Option Explicit
. It will help you to find out, which variables are not defined, and sometimes to avoid errors related to variable names missprint.
Here is your code, fixed and a little bit optimized:
Option Explicit' It is an option that turns on check for every used variable to be defined before execution. If this option is not defined, your code below will find undefined variables and define them when they are used. Good practice is to use this option, because it helps you, for example to prevent missprinting errors in variable names.
Sub Bezier()
Dim C as Double , t As Double
Dim k As Long, n As Long, i As Long
n = 3
For i = 0 To 100
t = i * 0.01
Cells(i + 2, 6) = 0
Cells(i + 2, 7) = 0
For k = 0 To n
C = (WorksheetFunction.Fact(n) / WorksheetFunction.Fact(k)) / WorksheetFunction.Fact(n - k)
Cells(i + 2, 6) = Cells(i + 2, 6).Value + Cells(k + 2, 1).Value * C * (t ^ k) * ((1 - t) ^ (n - k))
Cells(i + 2, 7) = Cells(i + 2, 7).Value + Cells(k + 2, 2).Value * C * (t ^ k) * ((1 - t) ^ (n - k))
Next
Next
End Sub
UPDATE
Here are some examples of factorial calculations.
Public Function fnFact(number) ' a simple cycle example of Factorial function
Dim tmp As Long ' new temporary variable to keep the "number" variable unchanged
tmp = number
fnFact = number
While tmp > 1
tmp = tmp - 1
fnFact = fnFact * tmp
Wend
End Function
Public Function fnFactR(number) ' a simple example of recursive function for Factorial calculation
If number > 0 Then
fnFactR = fnFactR(number - 1) * number ' function calls itself to continue calculations
Else
fnFactR = 1 ' function returns {1} when calculations are over
End If
End Function
Sub Factor_test() 'RUN ME TO TEST ALL THE FACTORIAL FUNCTIONS
Dim number As Long
number = 170 ' change me to find Factorial for a different value
MsgBox "Cycle Factorial:" & vbNewLine & number & "!= " & fnFact(number)
MsgBox "WorksheetFunction Factorial:" & vbNewLine & number & "!= " & WorksheetFunction.Fact(number)
MsgBox "Recursive Factorial:" & vbNewLine & number & "!= " & fnFactR(number)
End Sub
All those functions are available to calculate Factorial only for numbers before 170 inclusively, because of large result value.
So for my PC the limitation for WorksheetFunction.Fact()
function is also 170.
Let me know, if your PC has different limitation for this function, — it’s quite interesting thing.
UPDATE2
It is recomended to use Long
data type instead of Integer
each type when integer (or whole number) variable is needed. Long
is slightly faster, it has much wider limitations and costs no additional memory. Here are proof links:
1. MSDN:The Integer, Long, and Byte Data Types
2. ozgrid.com:Long Vs Integer
3. pcreview.co.uk:VBA code optimization — why using long instead of integer?
Thanks for @Ioannis and @chris neilsen for the information about Long
data type and proof links!
Good luck in your further VBA actions!
Return to VBA Code Examples
This article will demonstrate how to Fix VBA Error 438 – Object Doesn’t Support Property or Method.
Error 438 is a frequently occuring error in Excel VBA and is caused by either omitting a property or method when referring to an object, or by using a property or method that is not available to an object in the VBA code.
Check the VBA code to Fix Error 438
Let us examine the following code:
Sub RemoveWorksheet()
Dim wb As Workbook
Dim ws As Worksheet
Dim sheetName As String
sheetName = "Sheet 1"
Set wb = ActiveWorkbook
For Each ws In wb.Sheets
If ws = sheetName Then
wb.Sheets(sheetName).Delete
Exit For
End If
Next ws
End Sub
If we run this code, Error 438 will occur.
To resolve this issue, we click on Debug to see where the error is occurring.
This line of code is trying to equate the worksheet (depicted by the variable ws) to the sheet name. This is not possible as the worksheet is an object but the sheet name is a string so Error 438 is therefore returned.
To solve this, compare the string sheetName to the name property of the worksheet object:
ws.name = sheetName
Now the code runs without issue!
To show a list of all the properties or methods that are available to the worksheet object, we can type a dot (.) after the object.
This invokes the VBA Editor’s Intellisense feature. To make sure it’s turned on, in the Menu, select Tools > Options.
Make sure Auto List Members is checked and then click OK.
NOTE: This is usually on by default.
You can also find a list of all the Properties, Methods and Events for an Excel Object in the Object Browser.
In the Menu, select View > Object Browser or press F2 (See more VBE shortcuts).
A list of classes and objects will appear in the left hand side of the screen. If you click on the object you wish to use (eg: Workbook), a list of all the Properties, Methods and Events that that object supports will appear in the right hand side of the screen. (eg: Members of Workbook).
VBA Coding Made Easy
Stop searching for VBA code online. Learn more about AutoMacro — A VBA Code Builder that allows beginners to code procedures from scratch with minimal coding knowledge and with many time-saving features for all users!
Learn More!
Ошибка выполнения 438 часто обнаруживается при запуске макросов Microsoft Excel и Visual Basic. Ошибка возникает, когда макросы, которые вы пытаетесь использовать, являются неправильными или ошибочными и, как правило, препятствуют максимально плавной работе Excel. Если у вас есть эта ошибка на вашем компьютере, вы должны быть уверены, что сможете исправить ее наиболее эффективным способом.
Эта ошибка часто появляется в таком формате:
- Ошибка времени запуска «438»:
- Объект не поддерживает это свойство или метод
Сама ошибка вызвана используемым вами макросом или попыткой использовать устаревшие функции (если вы создали макрос в более ранней версии Office и теперь позволяете ему работать в Office 2010), или если макрос просто не работает. Это вообще не работает. Эту проблему можно решить, исправив макрос, который вы пытаетесь использовать, или восстановив установку Microsoft Office на вашем компьютере.
438 Первым шагом в устранении ошибки является удаление подключаемого модуля Microsoft Works для Office. Это часто вызывает конфликты с программным обеспечением Office. Это можно сделать, нажав «Пуск»> «Панель управления»> «Установка и удаление программ», а затем «Плагин Microsoft Works». Его удаление должно остановить дальнейший конфликт в вашей системе.
После удаления этого плагина следует использовать Microsoft Hotfix # 50356. Он специально разработан для решения проблем с ошибкой 438 и, в основном, позволяет вашему компьютеру работать максимально плавно, не удаляя другое программное обеспечение, которое вы хотите использовать.
Вам также следует использовать так называемую программу «Очиститель реестра», чтобы исправить потенциальные ошибки в базе данных реестра вашего компьютера. База данных реестра — это центральная система хранения всех файлов, настроек и настроек, которые Windows использует для ее запуска. Хотя эта база данных очень важна для вашего компьютера, она постоянно вызывает множество потенциальных проблем для вашего компьютера. Ошибка Runtime 438 может возникнуть, если база данных реестра повреждена, поэтому рекомендуется очистить эту базу данных вашей системы с помощью средства очистки реестра.
Выполнение этих шагов не только решит потенциальные проблемы на вашем компьютере, но и исправит ошибки, из-за которых ваш компьютер отображает 438 ошибок рабочего времени. Вы должны выполнить каждый шаг, чтобы исправить ошибку 438 навсегда.
Содержание
- Как исправить ошибку Microsoft Excel 438
- Основы «Excel Error 438»
- Что запускает ошибку времени выполнения 438?
- Типичные ошибки Excel Error 438
- Корень проблем Excel Error 438
- Fix VBA Error 438 – Object Doesn’t Support Property or Method
- Check the VBA code to Fix Error 438
- VBA Coding Made Easy
- VBA Code Examples Add-in
- Как исправить время выполнения Ошибка 438 Ошибка выполнения 438 — объект не поддерживает это свойство или метод
- Как исправить ошибку Microsoft Excel 438
- Основы «Excel Error 438»
- Что запускает ошибку времени выполнения 438?
- Типичные ошибки Excel Error 438
- Корень проблем Excel Error 438
Как исправить ошибку Microsoft Excel 438
Номер ошибки: | Ошибка 438 | |
Название ошибки: | Excel Error 438 | |
Описание ошибки: | Ошибка 438: Возникла ошибка в приложении Microsoft Excel. Приложение будет закрыто. Приносим извинения за неудобства. | |
Разработчик: | Microsoft Corporation | |
Программное обеспечение: | Microsoft Excel | |
Относится к: | Windows XP, Vista, 7, 8, 10, 11 |
Основы «Excel Error 438»
«Excel Error 438» обычно является ошибкой (ошибкой), обнаруженных во время выполнения. Разработчики программного обеспечения, такие как Microsoft Corporation, обычно принимают Microsoft Excel через несколько уровней отладки, чтобы сорвать эти ошибки перед выпуском для общественности. Ошибки, такие как ошибка 438, иногда удаляются из отчетов, оставляя проблему остается нерешенной в программном обеспечении.
Некоторые люди могут столкнуться с сообщением «Excel Error 438» во время работы программного обеспечения. Когда появится ошибка, пользователи компьютеров смогут уведомить разработчика о наличии ошибки 438 через отчеты об ошибках. Затем Microsoft Corporation исправит ошибки и подготовит файл обновления для загрузки. Чтобы исправить такие ошибки 438 ошибки, устанавливаемое обновление программного обеспечения будет выпущено от поставщика программного обеспечения.
Сбой устройства или Microsoft Excel обычно может проявляться с «Excel Error 438» в качестве проблемы во время выполнения. Рассмотрим распространенные причины ошибок ошибки 438 во время выполнения:
Ошибка 438 Crash — Ошибка 438 остановит компьютер от выполнения обычной программной операции. Это возникает, когда Microsoft Excel не реагирует на ввод должным образом или не знает, какой вывод требуется взамен.
Утечка памяти «Excel Error 438» — ошибка 438 утечка памяти приводит к увеличению размера Microsoft Excel и используемой мощности, что приводит к низкой эффективности систем. Потенциальные триггеры могут быть «бесконечным циклом», или когда программа выполняет «цикл» или повторение снова и снова.
Error 438 Logic Error — Ошибка программной логики возникает, когда, несмотря на точный ввод от пользователя, производится неверный вывод. Он материализуется, когда исходный код Microsoft Corporation ошибочен из-за неисправного дизайна.
Microsoft Corporation проблемы файла Excel Error 438 в большинстве случаев связаны с повреждением, отсутствием или заражением файлов Microsoft Excel. Как правило, самый лучший и простой способ устранения ошибок, связанных с файлами Microsoft Corporation, является замена файлов. Запуск сканирования реестра после замены файла, из-за которого возникает проблема, позволит очистить все недействительные файлы Excel Error 438, расширения файлов или другие ссылки на файлы, которые могли быть повреждены в результате заражения вредоносным ПО.
Типичные ошибки Excel Error 438
Типичные ошибки Excel Error 438, возникающие в Microsoft Excel для Windows:
- «Ошибка приложения Excel Error 438.»
- «Excel Error 438 не является приложением Win32.»
- «Извините, Excel Error 438 столкнулся с проблемой. «
- «Excel Error 438 не может быть найден. «
- «Excel Error 438 не найден.»
- «Ошибка запуска программы: Excel Error 438.»
- «Excel Error 438 не работает. «
- «Excel Error 438 остановлен. «
- «Неверный путь к программе: Excel Error 438. «
Обычно ошибки Excel Error 438 с Microsoft Excel возникают во время запуска или завершения работы, в то время как программы, связанные с Excel Error 438, выполняются, или редко во время последовательности обновления ОС. Документирование проблем Excel Error 438 в Microsoft Excel является ключевым для определения причины проблем с электронной Windows и сообщения о них в Microsoft Corporation.
Корень проблем Excel Error 438
Проблемы Excel Error 438 могут быть отнесены к поврежденным или отсутствующим файлам, содержащим ошибки записям реестра, связанным с Excel Error 438, или к вирусам / вредоносному ПО.
В частности, проблемы Excel Error 438 возникают через:
- Поврежденная или недопустимая запись реестра Excel Error 438.
- Файл Excel Error 438 поврежден от вирусной инфекции.
- Вредоносное удаление (или ошибка) Excel Error 438 другим приложением (не Microsoft Excel).
- Другое программное обеспечение, конфликтующее с Microsoft Excel, Excel Error 438 или общими ссылками.
- Поврежденная установка или загрузка Microsoft Excel (Excel Error 438).
Совместима с Windows 2000, XP, Vista, 7, 8, 10 и 11
Источник
Fix VBA Error 438 – Object Doesn’t Support Property or Method
This article will demonstrate how to Fix VBA Error 438 – Object Doesn’t Support Property or Method.
Error 438 is a frequently occuring error in Excel VBA and is caused by either omitting a property or method when referring to an object, or by using a property or method that is not available to an object in the VBA code.
Check the VBA code to Fix Error 438
Let us examine the following code:
If we run this code, Error 438 will occur.
To resolve this issue, we click on Debug to see where the error is occurring.
This line of code is trying to equate the worksheet (depicted by the variable ws) to the sheet name. This is not possible as the worksheet is an object but the sheet name is a string so Error 438 is therefore returned.
To solve this, compare the string sheetName to the name property of the worksheet object:
Now the code runs without issue!
To show a list of all the properties or methods that are available to the worksheet object, we can type a dot (.) after the object.
This invokes the VBA Editor’s Intellisense feature. To make sure it’s turned on, in the Menu, select Tools > Options.
Make sure Auto List Members is checked and then click OK.
NOTE: This is usually on by default.
You can also find a list of all the Properties, Methods and Events for an Excel Object in the Object Browser.
In the Menu, select View > Object Browser or press F2 (See more VBE shortcuts).
A list of classes and objects will appear in the left hand side of the screen. If you click on the object you wish to use (eg: Workbook), a list of all the Properties, Methods and Events that that object supports will appear in the right hand side of the screen. (eg: Members of Workbook).
VBA Coding Made Easy
Stop searching for VBA code online. Learn more about AutoMacro — A VBA Code Builder that allows beginners to code procedures from scratch with minimal coding knowledge and with many time-saving features for all users!
VBA Code Examples Add-in
Easily access all of the code examples found on our site.
Simply navigate to the menu, click, and the code will be inserted directly into your module. .xlam add-in.
Источник
Как исправить время выполнения Ошибка 438 Ошибка выполнения 438 — объект не поддерживает это свойство или метод
В этой статье представлена ошибка с номером Ошибка 438, известная как Ошибка выполнения 438 — объект не поддерживает это свойство или метод, описанная как Ошибка выполнения 438 — объект не поддерживает это свойство или метод. Наиболее частой причиной ошибки 438 является несоблюдение бинарной совместимости между последовательными версиями ваших компонентов. Каждый COM-интерфейс имеет связанный GUID, который называется inte
Информация об ошибке
Имя ошибки: Ошибка выполнения 438 — объект не поддерживает это свойство или метод
Номер ошибки: Ошибка 438
Описание: Ошибка выполнения 438 — объект не поддерживает это свойство или метод. Наиболее частой причиной ошибки 438 является несоблюдение бинарной совместимости между последовательными версиями ваших компонентов. Каждый COM-интерфейс имеет связанный GUID, который называется inte
Программное обеспечение: ActiveX
Разработчик: Microsoft
Этот инструмент исправления может устранить такие распространенные компьютерные ошибки, как BSODs, зависание системы и сбои. Он может заменить отсутствующие файлы операционной системы и библиотеки DLL, удалить вредоносное ПО и устранить вызванные им повреждения, а также оптимизировать ваш компьютер для максимальной производительности.
О программе Runtime Ошибка 438
Время выполнения Ошибка 438 происходит, когда ActiveX дает сбой или падает во время запуска, отсюда и название. Это не обязательно означает, что код был каким-то образом поврежден, просто он не сработал во время выполнения. Такая ошибка появляется на экране в виде раздражающего уведомления, если ее не устранить. Вот симптомы, причины и способы устранения проблемы.
Определения (Бета)
Здесь мы приводим некоторые определения слов, содержащихся в вашей ошибке, в попытке помочь вам понять вашу проблему. Эта работа продолжается, поэтому иногда мы можем неправильно определить слово, так что не стесняйтесь пропустить этот раздел!
- Двоичный — двоичный, система счисления с основанием 2, представляет числа с помощью двух символов: 0 и 1.
- Двоичная совместимость — Двоичная совместимость — это, как правило, способность двух программно-аппаратных систем запускать один и тот же двоичный код без необходимости перекомпиляции.
- Совместимость . Этот тег следует использовать для определения вопросов, касающихся проблем совместимости, например, между разными версиями одного и того же программного продукта, комплекта средств разработки или библиотеки.
- Компоненты — компонент в унифицированном языке моделирования «представляет собой модульную часть системы, которая инкапсулирует его содержимое и чье воплощение можно заменить в его среде.
- Guid — Глобально уникальный идентификатор GUID — это уникальный ссылочный номер, используемый в качестве идентификатора в компьютерном программном обеспечении. Интерфейс — интерфейс относится к точке взаимодействия между компонентами.
- Объект — объект — это любой объект, которым можно управлять с помощью команд на языке программирования.
- Время выполнения — время выполнения — это время, в течение которого программа работает, выполняя
- ошибка выполнения — среда выполнения ошибка обнаруживается после или во время выполнения программы.
- Свойство . В некоторых объектно-ориентированных языках программирования свойство представляет собой особый вид члена класса, промежуточный между поле или член данных и метод.
- Метод . Метод, часто называемый функцией, подпрограммой или процедурой, — это код, который выполняет задачу и связан с классом или объектом.
Симптомы Ошибка 438 — Ошибка выполнения 438 — объект не поддерживает это свойство или метод
Ошибки времени выполнения происходят без предупреждения. Сообщение об ошибке может появиться на экране при любом запуске %программы%. Фактически, сообщение об ошибке или другое диалоговое окно может появляться снова и снова, если не принять меры на ранней стадии.
Возможны случаи удаления файлов или появления новых файлов. Хотя этот симптом в основном связан с заражением вирусом, его можно отнести к симптомам ошибки времени выполнения, поскольку заражение вирусом является одной из причин ошибки времени выполнения. Пользователь также может столкнуться с внезапным падением скорости интернет-соединения, но, опять же, это не всегда так.
(Ошибка выполнения 438 — объект не поддерживает это свойство или метод) Repair Tool»/>
(Только для примера)
Причины Ошибка выполнения 438 — объект не поддерживает это свойство или метод — Ошибка 438
При разработке программного обеспечения программисты составляют код, предвидя возникновение ошибок. Однако идеальных проектов не бывает, поскольку ошибки можно ожидать даже при самом лучшем дизайне программы. Глюки могут произойти во время выполнения программы, если определенная ошибка не была обнаружена и устранена во время проектирования и тестирования.
Ошибки во время выполнения обычно вызваны несовместимостью программ, запущенных в одно и то же время. Они также могут возникать из-за проблем с памятью, плохого графического драйвера или заражения вирусом. Каким бы ни был случай, проблему необходимо решить немедленно, чтобы избежать дальнейших проблем. Ниже приведены способы устранения ошибки.
Методы исправления
Ошибки времени выполнения могут быть раздражающими и постоянными, но это не совсем безнадежно, существует возможность ремонта. Вот способы сделать это.
Если метод ремонта вам подошел, пожалуйста, нажмите кнопку upvote слева от ответа, это позволит другим пользователям узнать, какой метод ремонта на данный момент работает лучше всего.
Источник
Как исправить ошибку Microsoft Excel 438
Номер ошибки: | Ошибка 438 | |
Название ошибки: | Excel Error 438 | |
Описание ошибки: | Ошибка 438: Возникла ошибка в приложении Microsoft Excel. Приложение будет закрыто. Приносим извинения за неудобства. | |
Разработчик: | Microsoft Corporation | |
Программное обеспечение: | Microsoft Excel | |
Относится к: | Windows XP, Vista, 7, 8, 10, 11 |
Основы «Excel Error 438»
«Excel Error 438» обычно является ошибкой (ошибкой), обнаруженных во время выполнения. Разработчики программного обеспечения, такие как Microsoft Corporation, обычно принимают Microsoft Excel через несколько уровней отладки, чтобы сорвать эти ошибки перед выпуском для общественности. Ошибки, такие как ошибка 438, иногда удаляются из отчетов, оставляя проблему остается нерешенной в программном обеспечении.
Некоторые люди могут столкнуться с сообщением «Excel Error 438» во время работы программного обеспечения. Когда появится ошибка, пользователи компьютеров смогут уведомить разработчика о наличии ошибки 438 через отчеты об ошибках. Затем Microsoft Corporation исправит ошибки и подготовит файл обновления для загрузки. Чтобы исправить такие ошибки 438 ошибки, устанавливаемое обновление программного обеспечения будет выпущено от поставщика программного обеспечения.
Что запускает ошибку времени выполнения 438?
Сбой устройства или Microsoft Excel обычно может проявляться с «Excel Error 438» в качестве проблемы во время выполнения. Рассмотрим распространенные причины ошибок ошибки 438 во время выполнения:
Ошибка 438 Crash — Ошибка 438 остановит компьютер от выполнения обычной программной операции. Это возникает, когда Microsoft Excel не реагирует на ввод должным образом или не знает, какой вывод требуется взамен.
Утечка памяти «Excel Error 438» — ошибка 438 утечка памяти приводит к увеличению размера Microsoft Excel и используемой мощности, что приводит к низкой эффективности систем. Потенциальные триггеры могут быть «бесконечным циклом», или когда программа выполняет «цикл» или повторение снова и снова.
Error 438 Logic Error — Ошибка программной логики возникает, когда, несмотря на точный ввод от пользователя, производится неверный вывод. Он материализуется, когда исходный код Microsoft Corporation ошибочен из-за неисправного дизайна.
Microsoft Corporation проблемы файла Excel Error 438 в большинстве случаев связаны с повреждением, отсутствием или заражением файлов Microsoft Excel. Как правило, самый лучший и простой способ устранения ошибок, связанных с файлами Microsoft Corporation, является замена файлов. Запуск сканирования реестра после замены файла, из-за которого возникает проблема, позволит очистить все недействительные файлы Excel Error 438, расширения файлов или другие ссылки на файлы, которые могли быть повреждены в результате заражения вредоносным ПО.
Типичные ошибки Excel Error 438
Типичные ошибки Excel Error 438, возникающие в Microsoft Excel для Windows:
- «Ошибка приложения Excel Error 438.»
- «Excel Error 438 не является приложением Win32.»
- «Извините, Excel Error 438 столкнулся с проблемой. «
- «Excel Error 438 не может быть найден. «
- «Excel Error 438 не найден.»
- «Ошибка запуска программы: Excel Error 438.»
- «Excel Error 438 не работает. «
- «Excel Error 438 остановлен. «
- «Неверный путь к программе: Excel Error 438. «
Обычно ошибки Excel Error 438 с Microsoft Excel возникают во время запуска или завершения работы, в то время как программы, связанные с Excel Error 438, выполняются, или редко во время последовательности обновления ОС. Документирование проблем Excel Error 438 в Microsoft Excel является ключевым для определения причины проблем с электронной Windows и сообщения о них в Microsoft Corporation.
Корень проблем Excel Error 438
Проблемы Excel Error 438 могут быть отнесены к поврежденным или отсутствующим файлам, содержащим ошибки записям реестра, связанным с Excel Error 438, или к вирусам / вредоносному ПО.
В частности, проблемы Excel Error 438 возникают через:
- Поврежденная или недопустимая запись реестра Excel Error 438.
- Файл Excel Error 438 поврежден от вирусной инфекции.
- Вредоносное удаление (или ошибка) Excel Error 438 другим приложением (не Microsoft Excel).
- Другое программное обеспечение, конфликтующее с Microsoft Excel, Excel Error 438 или общими ссылками.
- Поврежденная установка или загрузка Microsoft Excel (Excel Error 438).
Совместима с Windows 2000, XP, Vista, 7, 8, 10 и 11
Источник
Frequently encountering Run-time error ‘438′: Object doesn’t support this property or method whenever you try to start work in Excel?
Don’t have any idea what causing this Excel runtime error 438 and how to fix it?
Well don’t get worried about it, as this post will help you to get the best fixes to resolve Excel error 438: Object doesn’t support this property or method error. Not only this, but you will also get complete information about this Excel error 438.
What Is Excel Runtime Error 438?
Mostly it is seen that the user stuck into such annoying error code in macro when the object doesn’t support by the property or method.
If any Excel user creates a toolbar in Excel by using visual basic code then also the following error code occurs:
Run-time error “438”: Object doesn’t support this property or method
To recover lost Excel objects, we recommend this tool:
This software will prevent Excel workbook data such as BI data, financial reports & other analytical information from corruption and data loss. With this software you can rebuild corrupt Excel files and restore every single visual representation & dataset to its original, intact state in 3 easy steps:
- Download Excel File Repair Tool rated Excellent by Softpedia, Softonic & CNET.
- Select the corrupt Excel file (XLS, XLSX) & click Repair to initiate the repair process.
- Preview the repaired files and click Save File to save the files at desired location.
Error Detail:
Error code: Run-time error ‘438′
Error name: Object doesn’t support this property or method
Error Screenshot:
What Are The Circumstances In Which Run-Time Error 438 In Excel Occurs?
There is not any specific reason for encountering this Excel runtime error 438: Object doesn’t support this property or method.
It is found that this Excel runtime error 438 occurs under several circumstances. So check this out:
- When anyone tries to make use of variables for workbooks and worksheet names.
- When executing a program within which form is already allotted to a variable. And that specific variable is now been used for accessing control over the form.
- This error also occurs when an installed AMD driver becomes out of date.
- The Macro you are using is maybe a wrong one or maybe it’s not working. Ultimately this will throw Excel runtime error 438.
- Runtime error 438 also encounters when you are trying to execute the designed macro of MS Excel previous version, into the latest MS Excel application.
- At the time of creating a custom toolbar in their Excel worksheet. User encounters a task failure error message i.e. “Object doesn’t support this property or method: Run-Time Error 438.
- In another instance in which this error occurs, the user tries to run the Microsoft VB for Excel macro. This macro tries to set the Excel worksheet properties but fails to complete this task which ultimately results in runtime error 438 in Excel.
After catching the complete idea of what can be the reasons for the Excel runtime error 438. Now you can easily make a keen check over the sections where this problem can generate.
How To Fix Runtime Error 438 In Excel?
Fix 1# MS Office Version Supporting Issue
Runtime error 438 in Excel also encounters while trying to work with the outdated macro function designed in older version MS Office application in some latest version of MS Office.
For this, I will recommend you to, use your macro in the respective version of MS Office application in which you have designed it. OR else you can get help from this helpful post [FIXED]: “This File is Not in Recognizable Format” Excel Error.
Fix 2# Check The Codings
As we have already discussed that Excel Runtime Error 438 also occurs due to the incorrect creation of a macro. Or when the user tries t0 run the macro which Excel objects don’t support property or method.
So, to resolve this Excel Object doesn’t support this property or method error user needs to check or rewrite the coding within the VBA module.
If you are not having good command over the programming then you can contact Microsoft Advisory Services.
Fix 3# Uninstall Microsoft Works Add-in:
It is seen that Microsoft works add-in generates this Excel Object doesn’t support this property or method error. So, uninstall this add-in just by following these steps:
- Go to the Start menu then click the Settings option and then on the Control Panel.
- Now tap to the Add / Remove Programs.
- Hit the File Location present within the Options.
- From Uninstall/Install tab, choose the add-in suit i.e Word in Works. After then tap the Add / Remove.
- Now carefully follow the screen instructions.
- Restart your PC and attempt to load Microsoft Word again.
This will stop the error from occurring again because you have successfully uninstalled the problem causing Works for Word add-in the program.
Fix 4# Use Microsoft Fix-It #50356
In many cases it is found that by downloading the Microsoft Fix-It #50356 user has successfully overcome the Excel error 438: Object doesn’t support this property or method.
So, you can also download the Microsoft Fix-It Patch from this link: https://support.microsoft.com/en-in/help/2970908/how-to-use-microsoft-easy-fix-solutions After complete downloading, the wizard will assist you throughout the tasks that you have to perform.
Through this Microsoft #50356 hotfix broken registry strings that are causing the issue can easily be repaired. This patch gives new keys on behave of broken registry keys. If your registry keys are broken then your Windows application displays the error message. But after downing this new patch in your PC your Window won’t show any error regarding Object doesn’t support this property or method.
If even after trying the above fixes the problem won’t resolve then move to the next solution.
Fix 5# Disable or Uninstall Windows Antivirus Software
Sometimes installed anti-viruses on your system also cause this runtime error 438. So, by disabling or uninstalling the anti-virus software you can easily get rid of this issue.
Steps to uninstall antivirus program from your PC:
- Open the control panel of your PC.
- After then make double-tap to Add/Remove Programs
- Choose the antivirus program which you want to uninstall from your PC. After then, tap to the Remove or Change/Remove option.
- Carefully follow the on-screen instructions for removing up the antivirus program. Once it gets over, restart your PC.
Fix 6# Reinstall The Device Drivers For The Device
Reinstalling the device driver can fix Excel Runtime Error 438. Try the following steps to resolve Object doesn’t support this property or method:
- Go to your system taskbar and make a tap on the start button. Here you will see a search box, in this box type device manager. After then choose the Device Manager.
- Make a right-click on the device name you need to uninstall and choose the Uninstall option.
- After uninstalling the device, restart your PC.
- Windows will try for driver reinstallation.
Fix 7: Resolve The Corruption Issue
Sometimes Excel sheet gets damaged or corrupt due to so many reasons like sudden system shutdown, software malfunction, virus attack, etc. Once the Excel spreadsheet gets corrupted /damaged you can’t access it anymore or it starts throwing error messages. So, the chances are high that some of your Excel file Objects got corrupted and thus it showing Object doesn’t support this property or method error.
Hence for the quick and easy solution to repair and restore corrupt Excel files go with the recommended option i.e Excel Repair Tool. It is the best software for repairing the damaged excel file.
* Free version of the product only previews recoverable data.
With this efficient repair tool, user can easily be able to fix all known errors that lead to corruption of excel files on Mac. It deeply scans the selected excel files without making any changes to the original content of the worksheet and fetches all the issues. It restores all the charts, objects, hidden sheets, pictures, clip charts, and other important Excel file content.
Wrap Up:
Carefully try all the above fixes to resolve runtime error 438 in Excel as some of the listed fixes may hamper your system settings if performed incorrectly. Even after trying all the above fixes if the Excel Object doesn’t support this property or method error won’t be resolved then let us inform by commenting in our comment section.
Priyanka is an entrepreneur & content marketing expert. She writes tech blogs and has expertise in MS Office, Excel, and other tech subjects. Her distinctive art of presenting tech information in the easy-to-understand language is very impressive. When not writing, she loves unplanned travels.
First of all, you should know, that some of functions, used on the worksheet, have limitations. So my point is avoid of using them in VBA, if it is not necessary.
For example, function POWER()
returns error on attempt to raise a zero to zero. An alternative is to use 0 ^ 0
combination, which is exactly doing the same, but looks more simply and operates without such error.
But also there is no embedded alternative in VBA to the FACT()
function, so you can use it, or simply add your own function factor()
— it’s uppon your choise.
If you just have started learning VBA, I would recomend you to use Option Explicit
. It will help you to find out, which variables are not defined, and sometimes to avoid errors related to variable names missprint.
Here is your code, fixed and a little bit optimized:
Option Explicit' It is an option that turns on check for every used variable to be defined before execution. If this option is not defined, your code below will find undefined variables and define them when they are used. Good practice is to use this option, because it helps you, for example to prevent missprinting errors in variable names.
Sub Bezier()
Dim C as Double , t As Double
Dim k As Long, n As Long, i As Long
n = 3
For i = 0 To 100
t = i * 0.01
Cells(i + 2, 6) = 0
Cells(i + 2, 7) = 0
For k = 0 To n
C = (WorksheetFunction.Fact(n) / WorksheetFunction.Fact(k)) / WorksheetFunction.Fact(n - k)
Cells(i + 2, 6) = Cells(i + 2, 6).Value + Cells(k + 2, 1).Value * C * (t ^ k) * ((1 - t) ^ (n - k))
Cells(i + 2, 7) = Cells(i + 2, 7).Value + Cells(k + 2, 2).Value * C * (t ^ k) * ((1 - t) ^ (n - k))
Next
Next
End Sub
UPDATE
Here are some examples of factorial calculations.
Public Function fnFact(number) ' a simple cycle example of Factorial function
Dim tmp As Long ' new temporary variable to keep the "number" variable unchanged
tmp = number
fnFact = number
While tmp > 1
tmp = tmp - 1
fnFact = fnFact * tmp
Wend
End Function
Public Function fnFactR(number) ' a simple example of recursive function for Factorial calculation
If number > 0 Then
fnFactR = fnFactR(number - 1) * number ' function calls itself to continue calculations
Else
fnFactR = 1 ' function returns {1} when calculations are over
End If
End Function
Sub Factor_test() 'RUN ME TO TEST ALL THE FACTORIAL FUNCTIONS
Dim number As Long
number = 170 ' change me to find Factorial for a different value
MsgBox "Cycle Factorial:" & vbNewLine & number & "!= " & fnFact(number)
MsgBox "WorksheetFunction Factorial:" & vbNewLine & number & "!= " & WorksheetFunction.Fact(number)
MsgBox "Recursive Factorial:" & vbNewLine & number & "!= " & fnFactR(number)
End Sub
All those functions are available to calculate Factorial only for numbers before 170 inclusively, because of large result value.
So for my PC the limitation for WorksheetFunction.Fact()
function is also 170.
Let me know, if your PC has different limitation for this function, — it’s quite interesting thing.
UPDATE2
It is recomended to use Long
data type instead of Integer
each type when integer (or whole number) variable is needed. Long
is slightly faster, it has much wider limitations and costs no additional memory. Here are proof links:
1. MSDN:The Integer, Long, and Byte Data Types
2. ozgrid.com:Long Vs Integer
3. pcreview.co.uk:VBA code optimization — why using long instead of integer?
Thanks for @Ioannis and @chris neilsen for the information about Long
data type and proof links!
Good luck in your further VBA actions!
First of all, you should know, that some of functions, used on the worksheet, have limitations. So my point is avoid of using them in VBA, if it is not necessary.
For example, function POWER()
returns error on attempt to raise a zero to zero. An alternative is to use 0 ^ 0
combination, which is exactly doing the same, but looks more simply and operates without such error.
But also there is no embedded alternative in VBA to the FACT()
function, so you can use it, or simply add your own function factor()
— it’s uppon your choise.
If you just have started learning VBA, I would recomend you to use Option Explicit
. It will help you to find out, which variables are not defined, and sometimes to avoid errors related to variable names missprint.
Here is your code, fixed and a little bit optimized:
Option Explicit' It is an option that turns on check for every used variable to be defined before execution. If this option is not defined, your code below will find undefined variables and define them when they are used. Good practice is to use this option, because it helps you, for example to prevent missprinting errors in variable names.
Sub Bezier()
Dim C as Double , t As Double
Dim k As Long, n As Long, i As Long
n = 3
For i = 0 To 100
t = i * 0.01
Cells(i + 2, 6) = 0
Cells(i + 2, 7) = 0
For k = 0 To n
C = (WorksheetFunction.Fact(n) / WorksheetFunction.Fact(k)) / WorksheetFunction.Fact(n - k)
Cells(i + 2, 6) = Cells(i + 2, 6).Value + Cells(k + 2, 1).Value * C * (t ^ k) * ((1 - t) ^ (n - k))
Cells(i + 2, 7) = Cells(i + 2, 7).Value + Cells(k + 2, 2).Value * C * (t ^ k) * ((1 - t) ^ (n - k))
Next
Next
End Sub
UPDATE
Here are some examples of factorial calculations.
Public Function fnFact(number) ' a simple cycle example of Factorial function
Dim tmp As Long ' new temporary variable to keep the "number" variable unchanged
tmp = number
fnFact = number
While tmp > 1
tmp = tmp - 1
fnFact = fnFact * tmp
Wend
End Function
Public Function fnFactR(number) ' a simple example of recursive function for Factorial calculation
If number > 0 Then
fnFactR = fnFactR(number - 1) * number ' function calls itself to continue calculations
Else
fnFactR = 1 ' function returns {1} when calculations are over
End If
End Function
Sub Factor_test() 'RUN ME TO TEST ALL THE FACTORIAL FUNCTIONS
Dim number As Long
number = 170 ' change me to find Factorial for a different value
MsgBox "Cycle Factorial:" & vbNewLine & number & "!= " & fnFact(number)
MsgBox "WorksheetFunction Factorial:" & vbNewLine & number & "!= " & WorksheetFunction.Fact(number)
MsgBox "Recursive Factorial:" & vbNewLine & number & "!= " & fnFactR(number)
End Sub
All those functions are available to calculate Factorial only for numbers before 170 inclusively, because of large result value.
So for my PC the limitation for WorksheetFunction.Fact()
function is also 170.
Let me know, if your PC has different limitation for this function, — it’s quite interesting thing.
UPDATE2
It is recomended to use Long
data type instead of Integer
each type when integer (or whole number) variable is needed. Long
is slightly faster, it has much wider limitations and costs no additional memory. Here are proof links:
1. MSDN:The Integer, Long, and Byte Data Types
2. ozgrid.com:Long Vs Integer
3. pcreview.co.uk:VBA code optimization — why using long instead of integer?
Thanks for @Ioannis and @chris neilsen for the information about Long
data type and proof links!
Good luck in your further VBA actions!