Pims.open Выдает «Неизвестную ошибку» с «Недопустимым Аргументом» На Одной Машине, Но Не на Другой

#python #video #ffmpeg #moviepy #pyav

Вопрос:

Я пытаюсь выполнить некоторую обработку видео для физического эксперимента, и я хочу сделать это на своем гораздо более мощном настольном компьютере с Windows, а не на ноутбуке Mac.

Следующий код работает как сон, когда он запускается как ноутбук Jupyter на моем Mac:

 import matplotlib as mpl
from mpl_toolkits import mplot3d
import pims
import trackpy as tp 

@pims.pipeline
def gray(image):
    return image[:, :, 1]  # Take just the green channel

frames = gray(pims.open('output.mp4'))
 

но на моей машине с Windows я получаю эту ошибку:

 ---------------------------------------------------------------------------
UnknownFormatError                        Traceback (most recent call last)
~AppDataLocalTemp/ipykernel_12152/704954007.py in <module>
      1 #Actually converts the video. Might be VERY processor intensive... or not?
----> 2 frames = gray(pims.open('output.mp4')) #Make the File Name whatever file you like!

~miniconda3libsite-packagespimsapi.py in open(sequence, **kwargs)
    207             warn(message)
    208             exceptions  = message   'n'
--> 209     raise UnknownFormatError("All handlers returned exceptions:n"   exceptions)
    210 
    211 

UnknownFormatError: All handlers returned exceptions:
<class 'pims.pyav_reader.PyAVReaderTimed'> errored: [Errno 22] Invalid argument: 'output.mp4'
<class 'pims.pyav_reader.PyAVReaderIndexed'> errored: [Errno 22] Invalid argument: 'output.mp4'
<class 'pims.imageio_reader.ImageIOReader'> errored: Could not load meta information
=== stderr ===

ffmpeg version 4.2.2 Copyright (c) 2000-2019 the FFmpeg developers
  built with gcc 9.2.1 (GCC) 20200122
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-amf --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt
  libavutil      56. 31.100 / 56. 31.100
  libavcodec     58. 54.100 / 58. 54.100
  libavformat    58. 29.100 / 58. 29.100
  libavdevice    58.  8.100 / 58.  8.100
  libavfilter     7. 57.100 /  7. 57.100
  libswscale      5.  5.100 /  5.  5.100
  libswresample   3.  5.100 /  3.  5.100
  libpostproc    55.  5.100 / 55.  5.100
C:UsersCallumOneDrive - The University of Chicagooutput.mp4: Invalid argument
<class 'pims.moviepy_reader.MoviePyReader'> errored: MoviePy error: failed to read the duration of file output.mp4.
Here are the file infos returned by ffmpeg:

ffmpeg version 4.2.2 Copyright (c) 2000-2019 the FFmpeg developers
  built with gcc 9.2.1 (GCC) 20200122
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-amf --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt
  libavutil      56. 31.100 / 56. 31.100
  libavcodec     58. 54.100 / 58. 54.100
  libavformat    58. 29.100 / 58. 29.100
  libavdevice    58.  8.100 / 58.  8.100
  libavfilter     7. 57.100 /  7. 57.100
  libswscale      5.  5.100 /  5.  5.100
  libswresample   3.  5.100 /  3.  5.100
  libpostproc    55.  5.100 / 55.  5.100
output.mp4: Invalid argument
 

вывод.mp4-это просто обычный видеофайл, снятый на CCD-камеру; Я попытался преобразовать его в .MOV, я пробовал другие видеофайлы, снятые на разных камерах, и я попытался запустить файл через FFmpeg, чтобы установить частоту кадров 30 кадров в секунду; все, что я пробовал, отлично работает на моем Mac и выдает вышеуказанную ошибку на моей машине с Windows.

Для справки, сегодня утром я установил необходимые пакеты для этого кода на обеих машинах, поэтому все они должны быть актуальными и одинаковыми на обеих.

Есть какие-нибудь идеи насчет того, что случилось? Спасибо!

Ответ №1:

Разобрался в проблеме! Я делился файлами между двумя машинами с помощью Microsoft OneDrive, которая создала псевдоним для видеофайлов, фактически не загружая их! Jupyter Notebook не смог определить разницу в проводнике файлов, но когда PIMS (или, точнее, PyAv) попытался загрузить файл, там ничего не было, что вызвало ошибку. Когда я загрузил файл на компьютер, все снова работало нормально.

Публикую это на случай, если это когда-нибудь случится с кем-нибудь еще! Спасибо.