Консольным приложением не был создан файл возможно ошибка или неверный формат pcf файла
Как бы доработать пример так, что сначала вызывается программа с параметрами "openssl.exe -a -b -c . ", далее она ожидает ввода с клавиатуры (если бы её запускать с cmd), нужно её подсунуть содержимое на сотню другую байт (контент), который она зашифрует и выдаст ответ, который и надо считать.
Вот считывание в примере и реализовано, но как бы сделать запись в консоль?
← →
брат Птибурдукова ( 2013-01-14 19:40 ) [1]
Создавай два пайпа. Второй запуздыривай сюда: hStdInput := GetStdHandle(STD_INPUT_HANDLE); // стандартный ввод не перенаправляем
← →
Игорь Шевченко © ( 2013-01-14 19:52 ) [3]
if not WasOK then
raise Exception.Create( "Ошибка выполнения или компиляции: " +
Chr( 10 ) + Chr( 13 ) + CommandLine )
Для интернетов самое то
← →
Игорь Шевченко © ( 2013-01-14 20:01 ) [4]
Ничего не получалось. Это приводило к тому, что консоль отображалась на экране, программа ничего не считывала (после данного кода шло считывание ReadFile).
Возник другой вопрос, почему я запускаю команду "ftp":
дальше стандартный код, подходим к считыванию данных из консоли:
>WasOK := ReadFile( StdOutPipeRead, Buffer, 255, BytesRead, nil );
на этом месте исполнение зависает навсегда. Хотя если в консоле набрать ftp, то мы видим приглашение:
Почему это приглашение "ftp>" не считывается?
Хотя писать можно, да.
Камрады, измучился весь с этим Openssl.exe
Есть такая команда:
> openssl.exe smime -sign -signer public.pem -inkey private.pem -nochain -nocerts -outform PEM -nodetach
Я пробовал после WriteFile делать:
Но ответом идет False с кодом GetLastError = 87, что означает:
"Параметр задан неверно".
После WriteFile делать CloseHandle(StdinPipeWrite) тоже пробовал.
Что делать? Как запустить openssl и передать в него текст, сообщив о конце передачи текста?! (
← →
Игорь Шевченко © ( 2013-01-18 20:39 ) [8]
от безысходности писал также:
тоже не получилось.
← →
брат Птибурдукова ( 2013-01-19 00:43 ) [11]
Попробуй в командной строке выполнить openssl.exe smime -sign -signer public.pem -inkey private.pem -nochain -nocerts -outform PEM -nodetach
> Попробуй в командной строке выполнить openssl.exe smime
> -sign -signer public.pem -inkey private.pem -nochain -nocerts
> -outform PEM -nodetach -in InFile.content
← →
брат Птибурдукова ( 2013-01-19 13:21 ) [13]
> Только в openssl это указывается доп. командой
Так ты уверен, что с перенаправлением вывода всё работает так же корректно, как с дополнительным параметром?
> Так ты уверен, что с перенаправлением вывода всё работает
> так же корректно, как с дополнительным параметром?
да, попробовал сейчас команду:
> openssl.exe smime -sign -signer public.pem -inkey private.pem -nochain -nocerts -outform PEM -nodetach
отработало просто на ура, тут же выдало ответ и вышло из программы openssl.
Причем, для openssl вроде как есть оттестированный рабочий код для PHP, его структура вроде бы понятна и на дельфи нечто такое же получается:
$descriptorspec = array(
0 => array("pipe", "r"), // stdin is a pipe that the child will read from
1 => array("pipe", "w"), // stdout is a pipe that the child will write to
2 => array("pipe", "w")); // stderr is a file to write to
$process = proc_open(
"openssl smime -sign -signer " . $certificate .
" -inkey " . $privkey .
" -nochain -nocerts -outform PEM -nodetach",
$descriptorspec, $pipes);
if (is_resource($process)) <
// $pipes now looks like this:
// 0 => writeable handle connected to child stdin
// 1 => readable handle connected to child stdout
fwrite($pipes[0], $source);
fclose($pipes[0]);
но тем не менее на дельфи изобразить не получается ((
← →
Игорь Шевченко © ( 2013-01-21 00:21 ) [16]
уже код пора выкладывать
try
// Создаём дочерний процесс, используя StdOutPipeWrite в качестве стандартного вывода,
// а так же проверяем, чтобы он не показывался на экране.
with SI do
Begin
FillChar( SI, SizeOf( SI ), 0 );
cb := SizeOf( SI );
dwFlags := STARTF_USESHOWWINDOW or STARTF_USESTDHANDLES;
wShowWindow := SW_HIDE or SW_SHOWMINNOACTIVE;
hStdInput := StdInPipeRead; //GetStdHandle(STD_INPUT_HANDLE);
hStdOutput := StdOutPipeWrite;
hStdError := StdOutPipeWrite;
end;
CommandLine := """ + FAppPath + "" " + FParam ;
sCurDir := ExtractFileDir(FAppPath);
WasOK := CreateProcess( nil,
PChar( CommandLine ),
nil,
nil,
True,
0,
nil,
PChar(sCurDir),
SI,
PI );
FhProcess := PI.hProcess ;
if Line <> "" then
OemToChar(PChar(Line), PChar(FAllRead)) ;>
SetEvent(FeventFinishRead) ;
// ждём, пока завершится консольное приложение
hArray[0] := pi.hProcess;
hArray[1] := FeventTerminate ;
WaitRes := WaitForMultipleObjects(2, @hArray, false, INFINITE);
if WaitRes = WAIT_OBJECT_0 then // значит, терминировался именно процесс запущенный
FStatus := prsEnd ;
FExitCode := 0;
GetExitCodeProcess( pi.hProcess, FExitCode );
finally
// Закрываем все оставшиеся дескрипторы
CloseHandle( PI.hThread );
CloseHandle( pi.hProcess );
end;
end;
finally
SetEvent(FeventFinishRead) ;
CloseHandle( StdOutPipeRead );
if StdInPipeWrite <> 0 then
CloseHandle( StdInPipeWrite );
if StdInPipeRead <> 0 then
CloseHandle(StdInPipeRead);
end;
end;
> WasOK := ReadFile(StdOutPipeRead, Buffer, 255, BytesRead, nil );
← →
Игорь Шевченко © ( 2013-01-21 15:34 ) [18]
WaitForInputIdle вставить не поможет перед началом работы с вводом-выводом?
> WaitForInputIdle вставить не поможет перед началом работы
> с вводом-выводом?
вставил перед WriteFile.
WaitForInputIdle(pi.hProcess, INFINITE) возвращает 0xFFFFFFFF.
GetLastError = 18: "Больше файлов не осталось"
Результата не дало.
← →
Игорь Шевченко © ( 2013-01-22 14:41 ) [21]
> // если процесс может быть создан, то дескриптор, это его
> вывод
> CloseHandle( StdOutPipeWrite );
Зачем этот вызов ?
← →
Игорь Шевченко © ( 2013-01-22 14:57 ) [22]
надо закрыть описатели записи в stdout и чтения stdin
Для того чтобы создать консольное приложение, надо в меню File выбрать команду New Project , в появившемся окне New Project выбрать CLR Console Application , в поле Name ввести имя проекта (рис. 6.2) и нажать кнопку OK . В результате этих действий станет доступным окно редактора кода, в котором можно набирать текст программы.
Рис. 6.2. Начало работы над консольным приложением
В качестве примера в листинге 6.2 приведен текст консольного приложения — утилиты clear, которая удаляет из каталога, указанного при запуске утилиты, и всех его подкаталогов tmp-файлы. Также, если при запуске утилиты указан ключ –CLEARDEBUG , утилита удаляет все файлы из всех подкаталогов Debug. Так как операция удаления является потенциально опасной, то утилита запрашивает у пользователя подтверждение на выполнение. Причем, чтобы операция очистки была начата, необходимо ввести Y , ввод любого другого символа, в том числе y , отменяет операцию. Основную работу — удаление файлов выполняет рекурсивная функция сlear. Сначала она обрабатывает (удаляет tmp-файлы) текущий каталог, затем формирует список подкаталогов
Часть II. Практикум программирования
текущего каталога, делает текущим первый (по номеру элементов списка) подкаталог и вызывает себя (рекурсия) для обработки этого подкаталога.
Листинг 6.2. Очистка диска (консольное приложение)
// clear.cpp : main project file.
using namespace System;
using namespace System::IO;
кол-во удаленных файлов
bool debug = true ;
bool clearDebug = false ; //
очистка каталогов Debug
// Очистка текущего каталога и всех его подкаталогов.
// подкаталоги текущего каталога
// файлы, которые надо удалить
int p = System::IO::Directory::GetCurrentDirectory()->
// удалить все файлы из каталога Debug
Files = Directory::GetFiles (System::IO::Directory::GetCurrentDirectory(),"*.*");
Глава 6. Консольное приложение
Files = Directory::GetFiles (System::IO::Directory::GetCurrentDirectory(),"*.tmp");
// удалить tmp-файлы из текущего каталога
Files = Directory::GetFiles (System::IO::Directory::GetCurrentDirectory(),"*.tmp");
int nf = Files->Length; for (i = 0; i if (! debug)
Console::WriteLine(Files[i] + " — удален"); nDel = nDel +1;
// обработать подкаталоги if (debug)
n = Directories->Length; for (i = 0; i if (debug) Console::WriteLine(Directories[i]);
Часть II. Практикум программирования
int main( array ^args)
char r; // ответ пользователя: Y или N
// проверим, указано ли имя файла теста if (args->Length == 0)
Console::WriteLine("Ошибка: Надо задать каталог."); Console::WriteLine("Команда: clear [-CLEARDEBUG]"); Console::WriteLine("-CLEARDEBUG — очистка каталогов Debug
");
Console::ReadLine(); return -1;
// проверим, существует ли указанный каталог try
catch (System::IO::DirectoryNotFoundException^ ex)
Console::WriteLine("Каталог " + path +" не найден");
Console::ReadLine(); return -1;
("Программа удалит все файлы из подкаталогов Debug");
Глава 6. Консольное приложение
Console::WriteLine("каталога "+ path+ " и всех его подкаталогов.");
Console::WriteLine("Программа удалит tmp-файлы");
Console::WriteLine("из каталога "+ path+
" и всех его подкаталогов.");
Console::ReadLine(); return -1;
Console::WriteLine("Удалено файлов: "+ nDel.ToString()); Console::WriteLine("Работа выполнена!"); Console::Write("Нажмите ");
Console::ReadLine(); return 0;
Построение консольного приложения выполняется обычным образом, т. е. выбором в меню Build команды Build Solution .
После успешной компиляции программу можно запустить. Для этого надо в меню Debug выбрать команду Start Debugging или Start Without Debugging .
Если программа должна получать параметры из командной строки, то при ее запуске из среды разработки параметры надо ввести в поле Command Arguments раздела Configuration Properties Debugging окна Property Page
(рис. 6.3), которое становится доступным в результате выбора в меню Project команды Properties . Следует обратить внимание: если в строке-параметре есть пробелы, то ее надо заключить в двойные кавычки.
У меня есть решение, которое имеет 3 проектов. Одним из них является консольным приложением и другие 2 являются окно приложения. Оба окна приложение использует консольное приложение, поэтому я добавил ссылку на консольном приложении в обеих окнах приложений проектов. Теперь, когда я строю окна проектов, консольное приложение копируется в выходной каталог, но проблема в том, что его конфигурационный файл «consoleapp.exe.config» не копируется!
Если бы я использовал библиотеку (сборки) вместо консольного приложения, он будет создан конфигурационный файл этой сборки в папке вывода.
Как решить эту проблему?
Выберите consoleapp.exe.config в дереве решений.
Выберите « Содержимое » для сборки Действие опции в собственности сетки.
Выберите Копировать всегда для копирования в каталог вывода опции.
Надеюсь, что это помогает 🙂
Быстрое создание консольного проекта в VS2008 и добавив « App.config », он имеет параметры:
Строить Действие: Нет
Скопировать в каталог Ouput: Не копировать
пользовательский инструмент:
Пользовательский инструмент Пространство имен:
Однако я не уверен, что эффект добавление ссылки на проект консоли будет иметь, как проект консоли представляет собой приложение, а не библиотеки классов.
Если вы хотите, чтобы консольное приложение для запуска с приложениями Windows, для отладки, то лучше, чем подход ссылок проекта будет установить решение для запуска нескольких приложений. Щелкните правой кнопкой мыши на решения, выберите свойства и на узле Start Project, выберите несколько проектов. (И удалить ссылки на консольное приложение.)
Ваши приложения используют значение по умолчанию для параметров из скомпилированного кода ссылочного проекта.
у меня есть два проекта, ProjectA и ProjectB . ProjectB есть консольное приложение, которое зависит от ProjectA . Вчера все работало нормально, но вдруг сегодня, когда я бегу ProjectB Я понимаю:
BadImageFormatException был необработанным:
Не удалось загрузить файл или сборку "ProjectA, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" или одну из ее зависимостей. Была сделана попытка загрузить программу, имеющую неверный формат.
вещи, которые я пробовал:
- убедитесь, что оба проекта настроены на "любой процессор" с помощью построить проверено. Они.
- убедитесь, что оба проекта предназначены для одной цели Рамки (Профиль Клиента .Net 4.0).
- в разделе ProjectB --> ссылки --> ProjectA -- > свойства, убедитесь, что "Копировать Локально" установлено значение "правда" _ (я проверил этот проект.dll копируется правильно)
- очистить/перестроить решение. Я даже попытался вручную удалить папки /bin и /obj в обоих проектах.
- Перезапустите Visual Studio. Перезагрузить компьютер.
- проверить совершенно новая копия хранилища.
Я уверен, что у вас 32-разрядная / 64-разрядная конфликта. Похоже, что ваш основной проект может быть установлен в 32-разрядный, А класс, на который он ссылается, - в 64-разрядный. Попробуйте посмотреть на это так вопрос и и это тоже. Между ними двумя, Вы должны быть в состоянии понять свою проблему.
возможно, вы столкнулись с проблемой с вашим сайтом после развертывания на сервере.
затем вам нужно настроить пул приложений для включения 32-разрядных приложений.
- открыть Диспетчер IIS
- нажмите на пулы приложений
- выберите пул приложений, который вы используете
- на правой панели выберите Дополнительные параметры.
- Set включить 32-разрядные приложения для Правда
Инструменты - > Параметры - > проекты и решения - > веб-проекты
Установить флажок это говорит: "используйте 64-разрядную версию IIS Express для веб-сайтов и проекты."
У меня была такая же проблема. Я установил "цель платформы" проекта A ("проект A"(щелкните правой кнопкой мыши)->Свойства->сборка->" цель платформы") в x86, но сохранил проект B в"любом процессоре". Задание проекта " Б " на "x86" это исправил.
У меня была эта проблема с запуском модульных тестов (xunit) в Visual Studio 2015 и наткнулся на следующее исправление:
возможно, Вам придется изменить Приложение, Бассейн настройка "Enable 32bit Applications" на TRUE в IIS7, если у вас есть по крайней мере 1 32bit dll\exe в вашем проекте.
вы также можете увидеть эту проблему, если вы пытаетесь упаковать 64-битный проект с установщиком MSI в VS. ("Причина в том, что родная прокладка упакована с помощью .MSI-файл представляет собой 32-разрядный исполняемый файл.")
ни одно из этих решений не сработало для меня, но, удалив содержимое папок bin и obj, все снова стало круто.
Я получил это при создании проекта через Visual Studio Online (VSTS) Build с помощью Visual Studio Build действия.
- удалить существующую исходную папку
- явно установите "любой процессор" в платформе для всех сборок Visual Studio, включая зависимости (см. снимок экрана ниже).
- повторно запустите сборку
Я столкнулся с такой же проблемой. Он выскочил из ниоткуда, и это показалось мне странным.
все проекты имели целевой процессор AnyCPU. Я изменил проект приложения ( проект, который ссылается на все другие проекты) на целевой процессор x86. Теперь это работает.
Не уверен, как целевой процессор перепутался без видимой причины, но это произошло.
Я также сталкиваются с этой проблемой в проекте, через несколько минут я нашел решение, эта проблема связана с конфигурацией CPU, Если вы используете Visual Studio 2010 или VS 2013, just goto project ' s свойства и выберите Compile из боковой панели, и будет 5 выпадающих, 5-й выпадающий будет целевой процессор:, вы должны установить его на x86 или x64 согласно вашим требованиям вместо любого К. П. У.
моя проблема была решена после замены его на x86.
а также это срабатывает, когда у вас есть оба упомянутых фреймворка, доступных в вашей системе.
в качестве обходного пути вызовите целевую структуру, которую вы собираетесь использовать для отладки в приложение.config
установите все пакеты ниже
распространяемые пакеты Visual C++ для Visual Studio 2013-vcredist_x64
распространяемые пакеты Visual C++ для Visual Studio 2013-vcredist_x86
распространяемые пакеты Visual C++ для Visual Studio 2012-vcredist_x64
распространяемые пакеты Visual C++ для Visual Studio 2012-vcredist_x86
прежде всего, я получил это в VS2017 со старым проектом, который мне нужно было сделать крошечные изменение и upraded все проекты в рамках 4.7.
есть несколько мест, где вам нужно это сделать, и это может быть не так просто, как выбор из раскрывающегося списка. Это исправило его для меня:
1) вам нужно сделать это оба здесь:
2), а также в Configuration Manager (правой кнопкой мыши на решение)
но что, если его не существует.
нажмите кнопку New и выберите следующие настройки: ( спасибо @RckLN)
Это может быть немного смешно, но у меня была такая же проблема с обычным рабочим кодом. Я добавил StreamWriter и StreamReader, и это дало эту ошибку. Решение было в том, что я взял этот код в скобки комментариев, затем отладил, и он снова начал работать
У меня также была эта проблема с запуском модульных тестов с помощью ReSharper в Visual Studio 2017 и исправлена со следующей конфигурацией:
моя машина показала мне обновление BIOS, и я задался вопросом, связано ли это с внезапным появлением этой ошибки. И после того, как я сделал обновление, ошибка была решена, и решение построено нормально.
Ошибка Неверный формат изображения может появиться при попытке запуска определенных приложений. Эта ошибка не позволит вам запустить нужные приложения, но есть несколько методов, которые можно использовать для решения этой проблемы.
Решение 1. Проверьте свой антивирус
Ваш антивирус может иногда мешать работе определенных приложений и вызывать ошибку Неверный формат изображения . Чтобы решить эту проблему, важно убедиться, что ваш антивирус не блокирует приложение, которое вы пытаетесь запустить, поэтому убедитесь, что приложение добавлено в список исключений.
Если это не помогает, возможно, вы можете попробовать отключить определенные антивирусные функции или вообще отключить антивирус. Если проблема не устранена, возможно, вам придется удалить антивирус. Даже если вы решите удалить сторонний антивирус, Защитник Windows должен оставаться защищенным в Windows 10, поэтому вам не нужно беспокоиться о вашей безопасности.
Если удаление антивируса решает проблему, вам следует подумать о переходе на другой антивирус. Антивирус Bitdefender предлагает отличную защиту, и если вы ищете антивирус, который не будет мешать вашей системе, мы рекомендуем вам попробовать его.
- ЧИТАЙТЕ ТАКЖЕ: имя каталога недопустимо [Fix]
Решение 2. Убедитесь, что приложение не пытается загрузить 32-разрядные библиотеки DLL.
Пользователи предлагают использовать Dependency Walker в режиме профиля, чтобы выяснить, какая DLL вызывает проблему. Просто скачайте этот инструмент и используйте его, чтобы открыть приложение, которое выдает эту ошибку, и вы сможете увидеть, какой файл DLL вызывает проблему.
Имейте в виду, что это продвинутое решение, поэтому, если вы обычный пользователь, который не знаком с Dependency Walker, возможно, вам следует пропустить это решение.
Решение 3. Выполните сканирование SFC или DISM
В некоторых случаях из-за повреждения файла может возникнуть ошибка Неверный формат изображения . Ваша система может иногда быть повреждена, и это может привести к этой и многим другим ошибкам. Тем не менее, вы можете решить проблему, просто выполнив SFC-сканирование. Это просто сделать, и вы можете сделать это, выполнив следующие действия:
- Запустите Командную строку от имени администратора. Вы можете сделать это быстро, используя сочетание клавиш Windows Key + X и выбрав Командная строка (Администратор) или PowerShell (Администратор) .
- Когда запустится Командная строка , введите sfc/scannow и нажмите Enter , чтобы запустить его.
- Процесс сканирования начнется. Сканирование может занять около 15 минут или более, поэтому не прерывайте его.
- Запустите Командную строку от имени администратора.
- Введите команду DISM/Online/Cleanup-Image/RestoreHealth и нажмите Enter , чтобы запустить ее.
- Сканирование DISM начнется. Это сканирование может занять около 20 минут или даже больше, поэтому не прерывайте его.
Решение 4. Убедитесь, что ваши драйверы обновлены
Для этого вам необходимо обновить все ваши важные драйверы, такие как чипсет, звук, сеть, графика и т. Д. Для этого вам необходимо посетить веб-сайт производителя для каждого из этих компонентов и загрузить последние версии драйверов для него.
Обновление драйверов вручную может быть немного утомительным, тем более что вам нужно знать модель каждого компонента, который вы пытаетесь обновить. Однако вы можете использовать сторонний инструмент, такой как TweakBit Driver Updater , который автоматически обновит все ваши драйверы всего за пару кликов.
- Загрузите программу обновления драйверов Tweakbit
Отказ от ответственности: некоторые функции этого инструмента не бесплатны
Решение 5. Обновите или переустановите DirectX
Если DirectX уже обновлен, вы можете попробовать переустановить его и проверить, решает ли это вашу проблему.
Решение 7. Переустановите приложение
Чтобы решить проблему, пользователи предлагают переустановить приложение и проверить, помогает ли это. Существует несколько методов, которые можно использовать для переустановки приложения, но многие пользователи предлагают использовать программное обеспечение для удаления, такое как IOBit Uninstaller .
В случае, если вы не знакомы, программа удаления удалит выбранное приложение, но также удалит все файлы и записи реестра, связанные с ним. Тем самым вы предотвратите любые оставшиеся файлы от вмешательства в вашу систему, и это будет так, как если бы приложение никогда не устанавливалось.
- Загрузить сейчас IObit Uninstaller PRO 7 бесплатно
После удаления приложения вам просто нужно установить его снова и проверить, решает ли это проблему.
Иногда при попытке запуска определенных игр может возникать ошибка Неверный формат изображения . Иногда ваша игровая установка может быть испорчена, и для решения проблемы рекомендуется проверить ее целостность. Это просто сделать в Steam, и вы можете сделать это, выполнив следующие действия:
- Откройте свою игровую библиотеку и найдите игру, которая дает вам эту ошибку. Нажмите его правой кнопкой мыши и выберите в меню Свойства .
- Перейдите на вкладку Локальные файлы и нажмите кнопку Проверить целостность файлов игры .
- Steam теперь проверит целостность вашего игрового кэша. Этот процесс может занять около 15 минут, иногда больше, в зависимости от размера игры.
Ошибка «Формат файла и расширение не соответствует» появляется, когда пользователь пытается открыть определенные файлы в Excel. Даже если пользователь нажмет на «Да», чтобы открыть его, вся ранее сохраненная информация об этом файле исчезнет.
Что вызывает ошибку «Формат файла и расширение не совпадают»?
Способ 1: изменение расширения вручную
Несколько затронутых пользователей, которые также сталкивались с этой проблемой, сообщили, что им удалось решить проблему, вручную изменив расширение (с помощью переименования) на различные популярные форматы Excel, пока они не нашли правильный.
Вот краткое руководство о том, как это сделать:
Если ни один из вышеуказанных форматов не работает или вы ищете другое решение проблемы, перейдите к следующему способу ниже.
Способ 2: разблокировка файла (если применимо)
Оказывается, ошибка «Формат файла и расширение не совпадает» также может возникать из-за того, что она заблокирована на уровне свойств. Это типичный случай, когда файлы загружаются через Интернет или принимаются в виде вложений электронной почты в качестве опции безопасности.
Вот краткое руководство по разблокировке файлов Excel, которые вызывают ошибки «Формат файла и расширение не совпадают» при запуске:
- Перейдите к месту, где хранится файл Excel, и щелкните по нему правой кнопкой мыши. Затем нажмите «Свойства» в появившемся контекстном меню.Свойства файла Excel
- Как только вы окажетесь в меню «Свойства», выберите вкладку «Общие» в горизонтальном меню вверху, затем прокрутите вниз до раздела «Безопасность» и просто нажмите кнопку «Разблокировать».Разблокировка файла
- Как только файл будет разблокирован, запустите его снова (перезапуск не требуется) и посмотрите, решена ли проблема.
Если ошибка «Формат файла и расширение не совпадает» все еще появляется, перейдите к следующему потенциальному исправлению ниже.
Способ 3: открытие файла сторонним аналогом
Несколько затронутых пользователей, которые также сталкивались с этой проблемой, подтвердили, что наконец смогли открыть файл Excel и редактировать, не обнаружив ошибки «Формат файла и расширение не совпадают», установив бесплатный эквивалент Excel и используя его, чтобы открыть проблемный файл.
Как оказалось, эта операция может в конечном итоге избежать поврежденных экземпляров, которые в конечном итоге делают файл недоступным для открытия. И если вы решите использовать OpenOffice, он, как известно, намного лучше удаляет поврежденные вложения из файлов Excel при переносе их в формат .ODS.
Вот что вам нужно сделать, чтобы открыть файл в стороннем эквиваленте:
Если ошибка «Формат файла и расширение не соответствует» все еще появляется, или вы ищете другое исправление, не требующее установки других сторонних компонентов, перейдите к следующему способу ниже.
Способ 4: отключение защищенного просмотра
Как выясняется, ошибка «Формат файла и расширение не совпадает» часто возникает из-за того, что довольно новый параметр безопасности (защищенное представление) не позволяет приложению Excel открывать определенные файлы, полученные с помощью вложений электронной почты.
Если этот сценарий применим, вы можете обойти этот параметр безопасности, открыв меню настроек Excel и полностью отключив функцию защищенного просмотра. Несколько затронутых пользователей, которые также были затронуты этой проблемой, подтвердили, что проблема была полностью решена.
Вот краткое руководство о том, как отключить защищенный просмотр в настройках Excel:
Примечание. Приведенные ниже шаги должны работать для каждой последней версии Excel (2010 и выше).
- Откройте Excel, а затем нажмите «Файл» на ленточной панели в верхней части экрана. Затем из меню «Файл» перейдите в «Параметры» в нижней части вертикального меню на левой боковой панели.
- После того, как вы окажетесь в меню параметров Excel, выберите вкладку Центр управления безопасностью в левой части панели.
- Как только вам удастся попасть в меню Центра управления безопасностью, перейдите на правую панель и нажмите Настройки центра управления безопасностью.
- В меню Центра управления безопасностью выберите Защищенные виды на левой панели. Затем переключите внимание на правую панель и снимите все флажки, связанные с каждым условием защищенного просмотра. После этого нажмите кнопку ОК, чтобы сохранить изменения.
- Как только вам удастся применить изменения, перезапустите приложение Excel и откройте окно презентации, которое ранее вызывало ошибку «Формат файла и расширение не совпадают».
Отключение защищенных представлений
Если ошибка формата и расширения файла не совпадает, перейдите к следующему способу ниже.
Но прежде чем сделать это, имейте в виду, что этот путь может сделать вашу систему уязвимой для эксплойтов в будущем. Но в случае, если затронутый компьютер является частью сети организации, это никоим образом не должно повлиять на вас.
- Нажмите клавишу Windows + R, чтобы открыть диалоговое окно «Выполнить». Как только вы окажетесь внутри поля «Выполнить», введите «regedit» и нажмите Enter, чтобы открыть редактор реестра. Когда вас попросит UAC (Контроль учетных записей), нажмите Да, чтобы предоставить административные привилегии.Regedit Command
- Как только вы окажетесь внутри утилиты редактора реестра, используйте правую панель, чтобы перейти к следующему местоположению: HKEY_CURRENT_USER Software Microsoft Office * X * Excel Security
Читайте также: