Содержание
- xlsxwriter и LibreOffice не показывает результат формулы
- 1 ответов
- Коды ошибок в LibreOffice Calc
- Libreoffice Writer пропадают формулы
- Лучи гнева.
- LibreOffice: страшный сон бухгалтера
- Введение
- Изменения с последней проверки в 2015 году
- Не дай себя обмануть
- Как не надо использовать массивы и векторы
- Как дважды ошибиться в макросах
- Опечаточки и copy-paste
- Странные циклы
- Странные условия
xlsxwriter и LibreOffice не показывает результат формулы
Я пытаюсь создать файл Excel с простой формулой:
созданный файл отлично работает в Excel, но при открытии в LibreOffice Calc формула не оценивается. Мне нужно повторно ввести числовые значения, и тогда это сработает.
что я делаю не так?
1 ответов
XlsxWriter не вычисляет результат формулы и вместо этого сохраняет значение 0 в качестве результата формулы. Затем он устанавливает глобальный флаг в файле XLSX сказать, что все формулы и функции должны быть пересчитаны при открытии файла. Это метод, рекомендованный в документации Excel, и в целом он отлично работает с приложениями электронных таблиц. Однако приложения, которые не имеют возможности для расчета формулы, такие как Excel Viewer или некоторые мобильные приложения будут отображать только 0 результатов.
Что касается того, почему пересчет не происходит автоматически, из ask.libreoffice.org ответ:
LibreOffice намеренно не пересчитывает старые электронные таблицы, потому что, поскольку формулы обновляются от версии к версии или между различными программами электронных таблиц, результаты могут быть разными. Перейти к инструментам-параметры-LibreOffice Calc, в разделе «пересчет при загрузке файла» измените два раскрывающихся списка: «Excel 2007 и новее» и «электронная таблица ODF (не сохраненная LibreOffice)» на «всегда пересчитывать». Нажмите кнопку ОК, закройте электронную таблицу и LibreOffice. Теперь откройте файл в LibreOffice, и вы увидите, что Формулы пересчитаны.
также перейдите в меню Сервис-содержимое ячейки и убедитесь, что Автокалькуляция выбранный.
Я подтвердил, что настройка «всегда пересчитывать «или» приглашение » работала для мне. Кроме того, вы всегда можете нажать control-shift-F9.
Источник
Коды ошибок в LibreOffice Calc
В следующей таблице описываются коды ошибок для LibreOffice Calc. Если ошибка происходит в ячейке, содержащей курсор, сообщение об ошибке отображается в строке состояния .
Ширины ячейки не хватает для отображения содержимого.
Символ в формуле недействителен.
Недопустимый аргумент функции. Например, отрицательное число в функции SQRT() (в этом случае следует использовать IMSQRT()).
Недопустимая операция с плавающей запятой
Вычисление приводит к переполнению определенного диапазона значений.
Ошибка в списке параметров
Недопустимый параметр функции, например, текст вместо числа или доменная ссылка вместо ссылки на ячейку.
Ошибка: нет пары
Отсутствует скобка: например, есть закрывающие скобки, но нет открывающих скобок.
Отсутствует оператор: например, в выражении «=2(3+4) * » нет оператора между символами «2» и «(«.
Нет переменной, например, в случае, когда два оператора стоят рядом «=1+*2».
Функция требует большего количества переменных, например, AND() и OR().
Слишком длинная формула
Компилятор: общее количество внутренних токенов (то есть операторов, переменных, скобок) в формуле превышает 8192.
Слишком длинная строка
Компилятор: идентификатор в формуле по размеру превышает 64 КБ. Интерпретатор: результат строковой операции по размеру превышает 64 КБ.
Операция сортировки, предпринятая на слишком большом количестве числовых данных (максимально 100000), или переполнение стека вычислений.
Внутренняя ошибка синтаксиса
В стеке вычислений предполагается матрица, но она недоступна.
Внутренняя ошибка синтаксиса
Неизвестный код: например, документ с новой функцией загружен в старую версию, не содержащую этой функции.
Внутренняя ошибка синтаксиса
Нет результата (в ячейке отображается #ЗНАЧЕН!, а не Ошибка:519)
Формула возвращает значение, не соответствующее определению, или ячейка, на которую ссылается формула, содержит текст вместо числа.
Внутренняя ошибка синтаксиса
Компилятор создал неизвестный код компиляции.
Внутренняя ошибка синтаксиса
Формула прямым или косвенным образом ссылается на себя, и не настроен параметр Циклы в разделе LibreOffice — Параметры Сервис — Параметры — LibreOffice Calc — Вычислить.
Процедура вычисления не сходится
Функция потеряла подбираемое значение или циклические ссылки не доходят до минимальных изменений для заданного максимального числа шагов.
недопустимые ссылки (вместо Ошибка:524 в ячейке содержится #ССЫЛ!)
Компилятор: не удалось определить имя описания столбца или строки. Интерпретатор: в формуле отсутствует столбец, строка или лист, содержащий ссылочную ячейку.
недопустимые имена (вместо Ошибка:525 ячейка содержит #ИМЯ?)
Идентификатор не может быть оценен (например, нет допустимой ссылки, нет допустимого доменного имени, нет подписи столбца/строки, нет макроса, неправильный десятичный разделитель, не найдена надстройка).
Внутренняя ошибка синтаксиса
Устарела, уже не используется, но может возникнуть из старых документов, если результатом является формула из домена.
Интерпретатор: ссылки (например, ссылка ячейки на ячейку) чрезмерно инкапсулированы.
Деление на ноль
Оператор деления/если знаменатель равен 0.
Эта ошибка возвращается некоторыми функциями, например:
VARP с менее чем 1 аргументом
STDEVP с менее чем 1 аргументом
ВАР с менее чем 2 аргументами
STDEV с менее чем 2 аргументами
STANDARDIZE с stdev=0
NORMDIST с stdev=0
Вложенные массивы не поддерживаются
Ошибка: Размер массива или матрицы
Неподдерживаемое содержимое встроенного массива
Внешнее содержимое отключено
Происходит, если встречается функция, требующая (повторной) загрузки внешних источников, а пользователь еще не подтвердил перезагрузку внешних источников.
Источник
Libreoffice Writer пропадают формулы
Иногда вставленная формула пропадает, а вместо нее остается просто прямоугольник. В этом году мне что-то с электроникой не везет. Доверять ответственную работу технике нельзя.
Ну и ССЗБ, что латехом не пользуешься!
напишите: номер версии libreoffice и последовательность действий, при которой наблюдается данная ошибка.
4.3.4.1 Какая последовательность? Просто пропадают неожиданно и все.
А почему в либре формулы работают чирижопу?
4.3.4.1 Какая последовательность? Просто пропадают неожиданно и все.
4.3.3.2. все работает. последовательность нужна для написания отчета об ошибке авторам, без неё ты просто пришел поныть.
Потому что либре- и прочие говноохфисы — порнография для абсолютных неосиляторов. А им пофиг, как формула выглядит: они все равно не понимают, что эта формула значит!
последовательность нужна для написания отчета об ошибке авторам
Вот тебе последовательность воспроизведения другой ошибки:
- открой LibreOffice Calc;
- выбери ячейку, контекстное меню, «формат ячейки»;
- во вкладке «обрамление» добавь сплошные границы дефолтной линией;
- во вкладке «выравнивание» поставь угол поворота текста 1 градус;
- примени изменения, нажав OK;
- наблюдай графические искажения.
Багу уже года полтора, наверное, если не больше. Описан, не исправлен.
Тут только ныть и остаётся, всё равно остальное не действует.
а в чем бага? в «выравнивании» есть Reference edge, поставь третий пункт. или я тебя не понял?
а в чем бага? в «выравнивании» есть Reference edge, поставь третий пункт. или я тебя не понял?
Да, третий пункт «чинит». Но это засовывание головы в песок. Ни при каких настройках выравнивания текста ободок не должен так выпирать, это баг.
Вот, кстати, ссылка: https://www.libreoffice.org/bugzilla/show_bug.cgi?id=35510 . Ему уже три с половиной года, оказывается.
а как оно должно выглядеть для первых двух пунктов? на что надо это исправить?
а как оно должно выглядеть для первых двух пунктов? на что надо это исправить?
Когда я поворачиваю текст на один градус, я ожидаю, что он повернётся на один градус, но при этом останется внутри ячейки. И ожидаю, что на границы ячейки поворот никак не будет влиять. Сейчас же текст и границы выбрасывает далеко в сторону.
В багзилле (ссылка была в сообщении выше) есть два вложения-скриншота, «как выглядит» и «как ожидается».
Доверять ответственную работу технике нельзя.
А людям — и подавно. И вообще, 4.3.4.* ещё нестабильна, о чём плач-то? Кстати, как обстоит дело с аппаратным ускорением графики?
Лучи гнева.
Потребовалось набить определённое не самое малое количество формул. И тут эта свистопляска. Самое интересное, что картинка объекта сохраняется, но если попытаться её отредактировать, то в формуле пусто. При сохранении в формат docx вместо формул пусто.
Обновляю версию из debian experimental до 4.4.2-rc2, надеюсь поможет.
P.S. грош цена переведённым комментариям исходного кода с немецкого на английский язык, если на ровном месте пропадают данные.
Я не знаю, как там в Дебиане, но в Убунте сборка жутко падучая и какая-то кривая. Правда, формулы у меня не пропадали. Но иногда они рендерятся крайне странно.
Но, конечно, когда возникает такой баг с формулами, лучше всего сделать копию документа и посмотреть, что там происходит в оригинальном XML.
Обновляю версию из debian experimental до 4.4.2-rc2, надеюсь поможет.
Не помогает, увы.
Если с тебя требуют doc, пиши сразу в MSOffice. Если не требуют, пиши в latex.
Спасибо, буду иметь в виду, но вывод очевиден. Пока лучше обходить либру стороной.
Если с тебя требуют doc, пиши сразу в MSOffice.
Нюанс, что требуют docx, но docx с формулами, собственно, в либре набираю исключительно формулы, сохраняю в docx, дальше судьба документа меня не интересует — не мой фронт работы.
При сохранении в формат docx вместо формул пусто.
Это, как раз, возможно. По форматам полной совместимости никто не обещал.
Это, как раз, возможно. По форматам полной совместимости никто не обещал.
Нет, нет. Тут не в конвертере дело. Пропадают формулы, у которых
картинка объекта сохраняется, но если попытаться её отредактировать, то в формуле пусто.
Единственное, что радует. Пропадают, кажется, только новые формулы, старые не исчезают.
Как оказалось, по крайней мере в AOO, при такой последовательности действий по умолчанию (растяжение текста относительно нижней части канта) поворачивается не только текст, но и скашиваются боковые грани обрамления, что наглядно видно, если поставить угол поворота, например, 30 градусов. Поэтому сам текст на самом деле остаётся внутри обрамлённой области, отрисовка которой вываливается за пределы «ячейки». Похоже, что это фича такая. Поэтому при малом угле наклона «ромб» обрамления сильно вытягивает. Остаётся непонятным, с чего это вдруг боковые грани обрамления вообще меняют угол при повороте текста?
Это точно. Ло вообще непредсказуем своим поведением.
Ну надо же, почти два года прошло с того сообщения, я и забыть успел. А в свежем (5.2.3.1) LibreOffice всё ещё воспроизводится.
Ага. Не помню, было ли это тогда, но сейчас при выборе угла есть ещё выбор привязки. Можно выбрать привязку к нижней кромке, верней кромке и к середине. По умолчанию выбрана привязка к нижней кромке, что и приводит к такому выбросу. Если поменять на привязку к центру, поведение становится ожидаемым.
Непонятно, зачем только по умолчанию стоит привязка к кромке.
В libreoffice 5.2.3.3 формулы пропадают. Причем все симптомы те же, что описал человек, создавший тему. Последовательность действий установить не удается.
Источник
LibreOffice: страшный сон бухгалтера
LibreOffice — мощный офисный пакет, который бесплатен для частного, образовательного и коммерческого использования. Его разработчики делают замечательный продукт, который во многих сферах используется в качестве альтернативы Microsoft Office. Команде PVS-Studio всегда интересно взглянуть на код таких известных проектов и попробовать найти в них ошибки. В этот раз сделать это было легко. Проект содержит много ошибок, которые могут привести к серьёзным проблемам. В статье будут рассмотрены некоторые интересные дефекты, найденные в коде.
Введение
LibreOffice — очень крупный C++ проект. Поддерживать проект такого объёма — сложная задача для команды разработчиков. И, к сожалению, складывается впечатление, что качеству кода LibreOffice не удаётся уделять достаточного внимания.
С одной стороны, проект просто огромный, не каждый инструмент статического или динамического анализа осилит анализ 13к файлов исходного кода. Столько файлов участвует в сборке офисного пакета вместе со сторонними библиотеками. В основном репозитории LibreOffice хранится около 8к файлов исходного кода. Такой объём кода создаёт проблемы не только разработчикам:
С другой стороны, у проекта много пользователей и требуется найти и исправить как можно больше ошибок. Каждая ошибка может причинять боль сотням и тысячам пользователей. Поэтому большой размер кодовой базы не должен становиться поводом отказаться от использования тех или иных инструментов, способных обнаружить ошибки. Думаю, читатель уже догадался, что речь идёт о статических анализаторах кода :).
Да, использование статических анализаторов не гарантирует отсутствия ошибок в проекте. Однако такие инструменты, как PVS-Studio, способны найти большое количество ошибок ещё на этапе разработки и тем самым уменьшить объём работ, связанных с отладкой и поддержкой проекта.
Давайте посмотрим, что можно найти интересного в исходных кодах LibreOffice, если взять статический анализатор кода PVS-Studio. Возможности запуска анализатора обширны: Windows, Linux, macOS. Для написания этого обзора использовался отчёт PVS-Studio, созданный при анализе проекта на Windows.
Изменения с последней проверки в 2015 году
В марте 2015 года был выполнен первый анализ LibreOffice («Проверка проекта LibreOffice») с помощью PVS-Studio. С тех пор офисный пакет сильно развился как продукт, но внутри всё также содержит множество ошибок. А некоторые паттерны ошибок вообще не поменялись с тех пор. Вот, например, ошибка из первой статьи:
V656 Variables ‘aVRP’, ‘aVPN’ are initialized through the call to the same function. It’s probably an error or un-optimized code. Consider inspecting the ‘rSceneCamera.GetVRP()’ expression. Check lines: 177, 178. viewcontactofe3dscene.cxx 178
Эта ошибка исправлена, но вот что нашлось в самой последней версии кода:
V656 Variables ‘aSdvURL’, ‘aStrURL’ are initialized through the call to the same function. It’s probably an error or un-optimized code. Consider inspecting the ‘pThm->GetSdvURL()’ expression. Check lines: 658, 659. gallery1.cxx 659
Как вы могли заметить, едва различимые составные имена функций до сих пор являются источником ошибок.
Ещё один интересный пример из старого кода:
V656 Variables ‘nDragW’, ‘nDragH’ are initialized through the call to the same function. It’s probably an error or un-optimized code. Consider inspecting the ‘rMSettings.GetStartDragWidth()’ expression. Check lines: 471, 472. winproc.cxx 472
Этот фрагмент кода действительно содержал ошибку, которая сейчас исправлена. Но ошибок в коде меньше не становится… Сейчас выявлена похожая ситуация:
V656 Variables ‘defaultZoomX’, ‘defaultZoomY’ are initialized through the call to the same function. It’s probably an error or un-optimized code. Consider inspecting the ‘pViewData->GetZoomX()’ expression. Check lines: 5673, 5674. gridwin.cxx 5674
Ошибки вносятся в код буквально по аналогии.
Не дай себя обмануть
V765 A compound assignment expression ‘x -= x — . ‘ is suspicious. Consider inspecting it for a possible error. swdtflvr.cxx 3509
Вот такой вот интересный «Hack» был найден с помощью диагностики V765. Если упростить строку кода с комментарием, то можно получить неожиданный результат:
И в чём тогда заключается Hack?
Ещё один пример на эту тему:
V567 The modification of the ‘nCount’ variable is unsequenced relative to another operation on the same variable. This may lead to undefined behavior. stgio.cxx 214
Выполнение кода в таких ситуациях может зависеть от компилятора и стандарта языка. Почему бы не переписать этот фрагмент кода проще, понятнее и надёжнее?
Как не надо использовать массивы и векторы
По какой-то причине кто-то понаделал множество однотипных ошибок при работе с массивами и векторами. Давайте разберём эти примеры.
V557 Array overrun is possible. The ‘nPageNum’ index is pointing beyond array bound. pptx-epptooxml.cxx 1168
Последним валидным индексом должно являться значение, равное size() — 1. Но в этом фрагменте кода допустили ситуацию, когда индекс nPageNum может иметь значение mpSlidesFSArray.size(), из-за чего происходит выход за пределы массива и работа с элементом, состоящим из «мусора».
V557 Array overrun is possible. The ‘mnSelectedMenu’ index is pointing beyond array bound. checklistmenu.cxx 826
Интересно, что в этом фрагменте кода написали проверку индекса более понятно, но при этом допустили такую же ошибку.
V557 Array overrun is possible. The ‘nXFIndex’ index is pointing beyond array bound. xestyle.cxx 2613
А эта ошибка вдвойне интереснее! В отладочном макросе написали правильную проверку индекса, а в другом месте снова сделали ошибку, допустив выход за пределы массива.
Теперь рассмотрим ошибку иного рода, не связанную с индексами.
V554 Incorrect use of shared_ptr. The memory allocated with ‘new []’ will be cleaned using ‘delete’. dx_vcltools.cxx 158
Этот фрагмент кода содержит ошибку, приводящую к неопределённому поведению программы. Дело в том, что память выделяется и освобождается разными способами. Для правильного освобождения памяти необходимо было объявить поле класса таким образом:
Как дважды ошибиться в макросах
V568 It’s odd that the argument of sizeof() operator is the ‘bTextFrame? aProps: aShapeProps’ expression. wpscontext.cxx 134
К сожалению для многих разработчиков, аргументы макросов ведут себя не как аргументы функций. Игнорирование этого факта часто приводит к ошибкам. В случаях #1 и #2 используется почти одинаковая конструкция с использованием тернарного оператора. Но в первом случае — макрос, во втором — функция. Однако это только вершина проблемы.
В случае #1 анализатор на самом деле обнаружил следующий код с ошибкой:
Это наш цикл с макросом SAL_N_ELEMENTS. Оператор sizeof не вычисляет выражение в тернарном операторе. В данном случае выполняется арифметика с размером указателей, результатом которой являются значения, далёкие от реального размера указанных массивов. На вычисление неправильных значений дополнительно влияет и разрядность приложения.
Но потом оказалось, что существует 2 макроса SAL_N_ELEMENTS! Т.е. препроцессор раскрыл не тот макрос, как же это могло произойти? Нам поможет определение макроса и комментарии разработчиков:
Другая версия макроса содержит безопасную шаблонную функцию, но что-то пошло не так:
- Безопасный макрос не включился в код;
- Другим макросом всё равно невозможно пользоваться, т.к. успешное инстанцирование шаблонной функции выполняется только если в тернарный оператор передать массивы одинакового размера. А в этом случае использование такого макроса теряет смысл.
Опечаточки и copy-paste
V1013 Suspicious subexpression f1.Pitch == f2.CharSet in a sequence of similar comparisons. xmldlg_export.cxx 1251
Ошибка является достойным кандидатом для пополнения статьи «Зло живёт в функциях сравнения», если мы когда-нибудь решим её обновить или расширить. Думаю, вероятность найти такую ошибку (пропуск f2.Pitch) самостоятельно крайне мала. А вы как считаете?
V501 There are identical sub-expressions ‘mpTable[ocArrayColSep] != mpTable[eOp]’ to the left and to the right of the ‘&&’ operator. formulacompiler.cxx 632
Результатом бездумного копирования стал такой фрагмент кода. Возможно, условное выражение просто продублировано лишний раз, но всё равно в коде не место таким неоднозначностям.
V517 The use of ‘if (A) <. >else if (A) <. >‘ pattern was detected. There is a probability of logical error presence. Check lines: 781, 783. mysqlc_databasemetadata.cxx 781
В результате копирования условных выражений, в коде была допущена ошибка, из-за которой значение 8 для переменной nColumnSize никогда не выставляется.
V523 The ‘then’ statement is equivalent to the ‘else’ statement. svdpdf.hxx 146
Тут перепутали функции min() и max(). Наверняка из-за этой опечатки в интерфейсе что-то странно масштабируется.
Странные циклы
V533 It is likely that a wrong variable is being incremented inside the ‘for’ operator. Consider reviewing ‘i’. javatypemaker.cxx 602
Выражение ++i в цикле выглядит очень подозрительно. Возможно, там должно быть ++j.
V756 The ‘nIndex2’ counter is not used inside a nested loop. Consider inspecting usage of ‘nIndex’ counter. treex.cxx 34
Есть какая-то ошибка во внутреннем цикле for. Т.к. переменная nIndex не изменяется, происходит перезаписывание одних и тех же двух элементов массива на каждой итерации. Скорее всего, везде вместо nIndex должна была использоваться переменная nIndex2.
V1008 Consider inspecting the ‘for’ operator. No more than one iteration of the loop will be performed. diagramhelper.cxx 292
Цикл for намеренно ограничивается до 1 итерации. Непонятно, зачем это сделано именно таким способом.
V612 An unconditional ‘return’ within a loop. pormulti.cxx 891
Пример более простого странного цикла из одной итерации, который лучше переписать на условный оператор.
Ещё несколько таких мест:
- V612 An unconditional ‘return’ within a loop. txtfrm.cxx 144
- V612 An unconditional ‘return’ within a loop. txtfrm.cxx 202
- V612 An unconditional ‘return’ within a loop. txtfrm.cxx 279
Странные условия
V637 Two opposite conditions were encountered. The second condition is always false. Check lines: 281, 285. authfld.cxx 281
Анализатор обнаружил противоречивые сравнения. Что-то с этим фрагментом кода явно не так.
Такой же код замечен и в этом месте:
- V637 Two opposite conditions were encountered. The second condition is always false. Check lines: 1827, 1829. doctxm.cxx 1827
V590 Consider inspecting this expression. The expression is excessive or contains a misprint. fileurl.cxx 55
Проблема приведённого фрагмента кода заключается в том, что первое условное выражение не влияет на результат всего выражения.
По мотивам подобных ошибок я даже написал теоретическую статью: «Логические выражения в C/C++. Как ошибаются профессионалы».
V590 Consider inspecting this expression. The expression is excessive or contains a misprint. unoobj.cxx 1895
Сразу не понять, в чём проблема данного условия, поэтому из препроцессированного файла был выписан развёрнутый фрагмент кода:
Получилось так, что ни одно число не входит одновременно в 4 диапазона, заданных в условии числами. Разработчики допустили ошибку.
Источник
From The Document Foundation Wiki
- Главная
- Разработка
- Дизайн
- QA
- События
- Документация
- Сайт
- Локализация
- Accessibility
- Маркетинг
- Diversity
- Wiki справка
- Документация
- Публикации
- Сторонняя документация
- ЧаВо
- HowTo
- Macros
- Документация для разработчиков
- Главная
- Общие
- Writer
- Calc
- Impress
- Draw
- Math
- Base
Что означают коды ошибок (Err: NNN ) в электронных таблицах LibreOffice?
Код ошибки | Текст | Описание |
---|---|---|
#### | any | Ячейка недостаточно большая для отображения всего содержимого. См. Как просмотреть содержимое ячейки, в которой отображается ###. |
501 | Invalid character | Не верный символ для этого контекста. Например:=1¤2 вместо =1E2. |
502 | Invalid argument | Аргумент функции имеет неправильное (недопустимое) значение. Например: отрицательное значение для функции извлечения корня. |
503 #NUM ! |
Incorrect floating point operation | Результат вычисления находится вне определенного диапазона значений. |
504 | Error in parameter list | Параметр функции имеет неверный тип. Например: текст вместо числа или ссылка на диапазон ячеек вместо ссылки на одну ячейку |
505 | Internal syntax error | Не используется |
506 | Incorrect decimal point | Не используется |
507 | Error : missing pair | Не используется |
508 | Error : missing pair | Закрывающая скобка без открывающей скобки или пропавшая закрывающая скобка в середине формулы (отсутствующая скобка в конце формулы добавляется автоматически). |
509 | Missing operator | Отсутствует оператор. Например: в формуле =2(3+4) отсутствует математический оператор (*, /, + или -) между цифрой «2» и открывающей скобкой «(«. |
510 | Missing variable | Недостающая переменная. Два оператора, где второй не является унарным оператором, следуют друг за другом. Например: =1+*2. |
511 | Missing variable | Недостающая переменная. Функция требует большего количества переменных, чем указано. Например: для операторов AND() и OR() не указаны параметры. |
512 | Formula too long | В компиляторе: это относится к внутреннему числу битов (512 максимум), которое не имеет ничего общего с длиной символьной строки в формуле, но зависит от количества операторов, переменных, скобок и т.д. в формуле. В интерпретаторе: формулы, которые генерируют слишком много матриц сразу (150 максимум) и основные функции, которые получают в качестве параметров массив, который слишком велик (OxFFE максимум в 65534 октета). |
513 | Character string too long | В компиляторе: идентификатор в формуле содержит более 255 символов. В интерпретаторе: результат операции над строкой символов содержит более 255 знаков. |
514 | Internal capacity exceeded | Операции сортировки со слишком большим количеством данных (максимум доступно 100 000) или данные, которые превышают стек вычислений |
515 | Internal syntax error | Не используется |
516 | Internal syntax error | Стек расчета должен содержать матрицу, но её не существует. |
517 | Internal syntax error | Неизвестный код операции. Например: документ, содержащий новую функцию, открыт в старой версии программного обеспечения, которая не содержит эту её. |
518 | Internal syntax error | Переменная должна появиться из стека вычислений, но её там нет. |
519 #VALUE ! | No result | Функция не может поставить значение, соответствующее определению, или одна из ячеек, на которую ссылается формула, содержит текст вместо числа |
520 | Internal syntax error | Компилятор сгенерировал код, который не может быть интерпретирован. |
521 | Internal syntax error | Нет результата в стеке вычисления. |
522 | Circular reference | Формула делает прямую или косвенную ссылку на саму себя и в меню Сервис ▸ Параметры ▸ LibreOffice Calc ▸ Вычисления не были активированы итерации. |
523 | The calculation does not converge | Статистические (финансовые) функции стремятся к заданному значению, но не достигают его, или итерация ссылок в цикле не достигает минимального изменения в рамках определенных шагом максимальных |
524 #REF ! |
Incorrect reference | В компиляторе: заголовки строк или столбцов не обнаружены. В интерпретаторе: формула ссылается на ячейку, столбец, строка или таблица которой были удалены или не входили в таблицу. |
525 #NAME ? |
Incorrect name | В компиляторе: система не может активировать идентификатор (нет ссылки, имени секции, заголовка строки или столбца, макроса, и так далее). В интерпретаторе: то же самое в течение всего периода выполнения. Например: функция Basic или надстройка недоступны. |
526 | Internal syntax error | Это уже не используется, но может произойти в старых документах, если результатом формулы был диапазон. |
527 | Internal capacity exceeded | В интерпретаторе: Чрезмерная вложенность ссылок (ячейка ссылается на ячейку, которая ссылается на ячейку, которая ссылается на ячейку и т.д.). |
532 #DIV/0 ! |
Division by zero | Оператор делений «/», где знаменатель равен «0» Другие функции могут возвращать эту ошибку. Например: VAR.P с менее чем 1 аргументом ECARTYPEP менее чем 1 аргументом VAR менее чем 2 аргументами ECARTYPE менее чем 2 аргументами CENTREE.REDUITE с ECARTYPE=0 LOI.NORMALE с ECARTYPE=0 |
A reference list of LibreOffice Calc error codes with explanations.
LibreOffice Calc offers feedback for errors, including miscalculations, improper function usage, invalid cell references or values, and other user mistakes. Depending on the specific error, this feedback can be shown within the cell itself, on the status bar, or even both.
Generally, the error message is displayed on the status bar if the error happens in the currently selected cell or the cell where the cursor is located.
Error codes for Cells
###
- Code: None
- Explanation: The column is too narrow to display the complete formatted contents of the cell. This is not really an error value, so there is no corresponding numerical error code. The solutions to this problem are to increase the width of the column. or select Format → Cells → Alignment and click either Wrap text automatically or Shrink to fit cell size to make the text match the current column width.
Err502
- Code: 502
- Explanation: The function argument is invalid, or the DGET function finds more than one matching cell.
#NUM!
- Code: 503
- Explanation: A calculation resulted in an overflow of the defined value range.
#VALUE
- Code: 519
- Explanation: The formula within the cell returns a value that does not correspond to the definition of the formula or functions used. This error could also mean that the cell referenced by the formula contains text
instead of a number.
#REF!
- Code: 524
- Explanation: The formula within the cell uses a reference that does not exist. Either a column or row description name could not be resolved, or the column, row, or sheet that contains a referenced cell is missing.
#NAME?
- Code: 525
- Explanation: An identifier could not be evaluated: no valid reference, no valid domain name, no column/row label, no macro, incorrect decimal divider, add-in not found. For example, entering in a cell =sum(bob*5) where there is no cell named “bob” or containing the text “bob” generates this error.
#DIV/0!
- Code: 532
- Explanation: Division operator / if the denominator is 0.
General Error Codes
Error code | Error message | Error description |
501 | Invalid character | Character in a formula is not valid. This error is the same as the Invalid Name error (525) except that it occurs within a formula. The cell containing the error will display the #NAME? error reference. |
502 | Invalid argument | Function argument is not valid; for example, a negative number for the root function. This error also occurs if more than one matching cell is found by the DGET function. |
503 | Invalid floating point operation (cell displays #NUM!) |
Division by 0, or another calculation that results in an overflow of the defined value range (a value too big or too Small). |
504 | Parameter list error | Function parameter is not valid; for example, text instead of a number, or a domain reference instead of a cell reference. |
505 | Internal syntax error | |
506 | Invalid semicolon | |
507 | Pair missing | |
508 | Pair missing | Missing bracket or parenthesis; for example, closing brackets but no opening brackets. |
509 | Missing operator | Operator is missing; for example, “=2(3+4) * “, where the operator between “2” and “(” is Missing. |
510 | Missing variable | Variable is missing; for example, when two operators are Together “=1+*2”. |
511 | Missing variable | Function requires more variables than are provided; for example, AND() and OR(). |
512 | Formula overflow | The total number of internal tokens (that is, operators, variables, brackets) in the formula exceeds 512, or the total number of matrices the formula creates exceeds 150. This includes basic functions that receive too large an array as a Parameter. |
513 | String overflow | An identifier in the formula exceeds 64 KB in size, or a result of a string operation exceeds 64 KB in size. |
514 | Internal overflow | Sort operation attempted on too much numerical data (max. 100000) or a calculation stack overflow. |
515 | Internal syntax error | Not used |
516 | Internal syntax error | Matrix is expected on the calculation stack, but is not Available. |
517 | Internal syntax error | Unknown error; for example, a document with a newer function is loaded in an older version of Calc that does not contain the function. |
518 | Internal syntax error | Variable is not available. |
519 | No result (cell displays #VALUE) |
Formula yields a value that does not correspond to the definition, or a cell that is referenced in the formula contains text instead of a number. |
520 | Internal syntax error | Compiler creates an unknown compiler code. |
521 | Internal syntax error | No result |
522 | Circular reference | Formula refers directly or indirectly to itself and the Iterations option is not selected under Tools → Options → LibreOffice Calc → Calculate. |
523 | The calculation procedure does not Converge |
Financial statistics function missed a targeted value, or iterations of circular references do not reach the minimum change within the maximum steps that are set. |
524 | Invalid references (cell displays #REF!) |
A column or row description name could not be resolved, or the column, row, or sheet that contains a referenced cell is Missing. |
525 | Invalid names (cell displays #NAME?) |
An identifier could not be evaluated; for example, no valid reference, no valid domain name, no column/row label, no macro, incorrect decimal divider, add-in not found. |
526 | Internal syntax error | Obsolete, no longer used, but could come from old documents if the result is a formula from a domain. |
527 | Internal overflow | References, such as when a cell references a cell, are too encapsulated or deeply nested. This is an internal error and should not be displayed in LibreOffice. |
528 to 531 | None | Not used |
532 | Division by zero | Division operator / if the denominator is 0. Some more functions return this error; for example: VARP with less than 1 argument STDEVP with less than 1 argument VAR with less than 2 arguments STDEV with less than 2 arguments STANDARDIZE with stdev=0 NORMDIST with stdev=0 |
Closing Notes
I hope you find the explanation for the LibreOffice Calc error for your spreadsheet and able to resolve it.
Related
Error Number: | Error 501 | |
Error Name: | Libreoffice Error 501 | |
Error Description: | Error 501: LibreOffice has encountered a problem and needs to close. We are sorry for the inconvenience. | |
Developer: | LibreOffice | |
Software: | LibreOffice | |
Applies to: | Windows XP, Vista, 7, 8, 10, 11 |
Examination of Libreoffice Error 501
Commonly, PC professionals refer to Libreoffice Error 501 as a type of «runtime error». Developers like LibreOffice usually go through several checkpoints before launching a software program like LibreOffice. Sadly, many errors can be missed, resulting in problems like those with error 501.
In the release of the latest version of LibreOffice, an error could be encountered that reads, «Libreoffice Error 501». After error 501 is encountered, the software user has the ability to inform the developer of this issue. LibreOffice then would need to correct these errors in the master source code and provide a modified version for downloading. If there’s a prompt for a LibreOffice update, it’s usually a workaround for fixing issues like error 501 and other bugs.
What Actually Causes Runtime Error 501?
A failure during the execution of LibreOffice is generally when you will encounter Libreoffice Error 501 as a runtime error. You can distinguish the causes of processing failures by categorizing error 501 errors as follows:.
Error 501 Crash — error 501 locks up any input and it can make the machine crash. When LibreOffice cannot provide sufficient output to the given input, or doesn’t really know what to output, it will often confuse the system in this manner.
Libreoffice Error 501 Memory Leak — When a LibreOffice memory leak happens, it will result in the operating system running sluggish due to a lack of system resources. It may be triggered by the misconfiguration of the software by LibreOffice, or when one command starts a loop which can’t be ended.
Error 501 Logic Error — A logical error occurs when the computer produces the wrong output, even if the input is right. This can happen when LibreOffice’s source code has a vulnerability regarding data handing.
LibreOffice problems with Libreoffice Error 501 most often stem from a corrupt or missing LibreOffice file. If your LibreOffice file is suffering from one of those troubles, replacing it with a fresh file should resolve the issue. After the problem file is replaced, running a registry scan can help clean up any invalid Libreoffice Error 501, file extension, or other file path references which could have been affected from a previous malware infection.
Common Libreoffice Error 501 Error Messages
These Libreoffice Error 501-related LibreOffice Troubles Include:
- «Libreoffice Error 501 Program Error.»
- «Libreoffice Error 501 not a Win32 program.»
- «Sorry for the inconvenience — Libreoffice Error 501 has a problem.»
- «Can’t locate Libreoffice Error 501»
- «Libreoffice Error 501 not found.»
- «Error starting program: Libreoffice Error 501.»
- «Libreoffice Error 501 not working.»
- «Libreoffice Error 501 failed.»
- «Libreoffice Error 501: App Path is Faulting.»
Usually Libreoffice Error 501 errors with LibreOffice happen during startup or shutdown, while Libreoffice Error 501 related programs are running, or rarely during the OS update sequence. Notating when Libreoffice Error 501 errors occur is paramount in finding the cause of the LibreOffice problems and reporting them to LibreOffice for help.
Libreoffice Error 501 Problem Causes
Libreoffice Error 501 problems can be attributed to corrupt or missing files, invalid registry entries associated with Libreoffice Error 501, or a virus / malware infection.
In particular, Libreoffice Error 501 problems originate through:
- Libreoffice Error 501 registry keys invalid / corrupted.
- Virus or malware corrupting Libreoffice Error 501.
- Malicious deletion (or mistaken) of Libreoffice Error 501 by another application (not LibreOffice).
- A different application in conflict with Libreoffice Error 501, or other shared references.
- LibreOffice (Libreoffice Error 501) corrupted during download or install.
Product by Solvusoft
Download Now
WinThruster 2023 — Scan your PC for computer errors.
Compatible with Windows 11, 10, 8, 7, Vista, XP and 2000
Optional Offer for WinThruster by Solvusoft | EULA | Privacy Policy | Terms | Uninstall
##### — эти символы сообщают, что столбец, содержащий числа, недостаточно широк, или же дата и время, введенные в ячейки данного столбца, содержат отрицательные числа. В первом случае достаточно просто увеличить ширину столбца или изменить числовой формат данных (например, уменьшить число знаков после запятой). Во втором же случае надо:
• проверить формулу, если вычисляется число дней между двумя датами;
• если формула не содержит ошибок, необходимо изменить формат ячейки и перейти, например, с формата Дата и время на Общий или Числовой формат.
Ошибка: 501 — недопустимый символ. Формула содержит недопустимый символ, например =1Eр вместо =1E2.
Ошибка: 502 — недопустимый аргумент. Функция имеет недопустимый аргумент, например отрицательное число для функции извлечения корня.
Ошибка: 503 (#NUM! ) — недопустимая операция с плавающей запятой. Вычисление приводит к переполнению диапазона значений.
Ошибка: 504 — ошибка в списке параметров. Используется недопустимый параметр функции, например текст вместо числа или гиперссылка вместо ссылки на ячейку.
Ошибка: 508 — нет пары.
Отсутствует скобка (закрывающая или открывающая).
Ошибка: 509 — отсутствует оператор. В формуле отсутствует оператор (+, – и т. д.).
Ошибка: 510 — отсутствует переменная.
Отсутствует переменная (два оператора стоят рядом).
Ошибка: 511 — отсутствует переменная. В функции не хватает переменной.
Ошибка: 512 — слишком длинная формула.
Общее число внутренних маркеров (операторов, переменных, скобок) в формуле превышает 512 или общее число матриц, которые создает формула, превышает 150.
Ошибка: 513 — слишком длинная строка. Идентификатор в формуле превышает 64 Kб.
Ошибка: 514 — внутреннее переполнение.
Переполнен стек вычислений (например, операция сортировки предпринята на слишком большом количестве числовых данных — более 100 000).
Ошибка: 516 — внутренняя синтаксическая ошибка. В стеке вычислений недоступна необходимая матрица.
Ошибка: 517 — внутренняя синтаксическая ошибка. Документ с новой функцией открыт в старой версии программы.
Ошибка: 518 — внутренняя синтаксическая ошибка. Переменная недоступна.
Ошибка: 519 (#VALUE) — нет результата. Ячейка, на которую ссылается формула, содержит текст вместо числа. -В ячейке отображается #ЗНАЧЕН! , а не Ошибка: 519.
Ошибка: 520 — внутренняя синтаксическая ошибка. Компилятор создал неизвестный код компиляции.
Ошибка: 521 — внутренняя синтаксическая ошибка. Нет результата.
Ошибка: 522 — циклическая ссылка. Формула ссылается прямо или косвенно на саму себя, а параметр Итерации не настроен.
Ошибка: 523 — процедура вычисления не сходится. Функция потеряла подбираемое значение или циклические ссылки не доходят до минимальных изменений для заданного максимального числа шагов.
Ошибка: 524 (#REF) — недопустимые ссылки. В формуле отсутствует столбец, строка или лист с заданной ячейкой.
-В ячейке отображается #ССЫЛ!2, а не Ошибка: 524.
Ошибка: 525 (#NAME) — недопустимые имена. Нет допустимой ссылки, доменного имени, подписи столбца/строки, макроса, присутствует неправильный десятичный разделитель или не найдена надстройка.
-В ячейке отображается #ИМЯ, а не Ошибка: 525.
Ошибка: 526 — внутренняя синтаксическая ошибка. Ссылка устарела.
Ошибка: 527 — внутреннее переполнение. Слишком сложное вложение ссылок.
Ошибка: 532 (#DIV/0!) — деление на ноль. В формуле используется деление на ноль.