繁体   English   中英

您如何阅读 Python Traceback 错误?

[英]How do you read a Python Traceback error?

我在 Windows 10 中运行了一些 Python 代码并得到下面的 Traceback 错误。 这是否意味着应该是 int 的字符串出现在 /DeOldify/deoldify/filters.py 的第347行或/DeOldify/deoldify/filters.py的第1943 /lib/site-packages/PIL/Image.py

对于上下文,在回溯错误下方,我还包含了导致此错误的步骤(我尝试根据 DeOldify Colab https://colab.research.google.com/github/为黑白电影剪辑着色jantic/DeOldify/blob/master/VideoColorizerColab.ipynb但仅成功地将第一帧着色为 a.jpeg)和完整的终端 output。

编辑:感谢@Daweo 的回复,我发现问题出在我输入终端的 arguments 上,如"<stdin>", line 1所示。 正确的命令应该是:
video_path = colorizer.colorize_from_file_name(file_name='my_video.mp4', render_factor=render_factor)
此外,为照片着色的代码来自https://colab.research.google.com/github/jantic/DeOldify/blob/master/ImageColorizerColab.ipynb

错误:

Traceback (most recent call last):----------------------------| 0.00% [0/1378 00:00<00:00]
  File "<stdin>", line 1, in <module>
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 347, in colorize_from_file_name
        return self._colorize_from_path(
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 359, in _colorize_from_path
        self._colorize_raw_frames(
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 273, in _colorize_raw_frames
        color_image = self.vis.get_transformed_image(
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 178, in get_transformed_image
        filtered_image = self.filter.filter(
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 121, in filter
        filtered_image = filter.filter(orig_image, filtered_image, render_factor, post_process)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 83, in filter
        model_image = self._model_process(orig=filtered_image, sz=render_sz)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 45, in _model_process
        model_image = self._get_model_ready_image(orig, sz)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 40, in _get_model_ready_image
        result = self._scale_to_square(orig, sz)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 37, in _scale_to_square
        return orig.resize(targ_sz, resample=PIL.Image.BILINEAR)
  File "C:\python-virtual-environments\lib\site-packages\PIL\Image.py", line 1943, in resize
        return self._new(self.im.resize(size, resample, box))
TypeError: an integer is required (got type str)

脚步:

- 使用 AviSynth 和 WinFF 将 5 秒的黑白电影提取为名为my_video.mp4的 UYVY.mp4 文件

C:\ffmpeg\bin\添加到路径

- 安装微软 C++ 构建工具

-设置虚拟Python环境

- pip install numpy scipy matplotlib ipython

- git clone https://github.com/jantic/DeOldify.git DeOldify

- cd DeOldify

- pip install torch

- pip install -r colab_requirements.txt

- mkdir models

- https://data.deepai.org/deoldify/ColorizeVideo_gen.pth下载到./models/ColorizeVideo_gen.pth

https://data.deepai.org/deoldify/ColorizeArtistic_gen.pth./models/ColorizeArtistic_gen.pth

-Python 命令:

from deoldify import device
from deoldify.device_id import DeviceId
#device.set(device=DeviceId.GPU0)
device.set(device=DeviceId.CPU)
import torch
import fastai
from deoldify.visualize import *
import warnings
warnings.filterwarnings("ignore", category=UserWarning, message=".*?Your .*? set is empty.*?")

- 将视频文件my_video.mp4重新定位到./DeOldify/video/source/my_video.mp4

colorizer = get_video_colorizer()
source_url = 'my_video.mp4'
render_factor = 21
watermarked = True

video_path = colorizer.colorize_from_file_name(source_url, 'video.mp4', render_factor)

结果是创建了一个带有黑白帧的目录./DeOldify/video/bwframes/my_video/ 但是,颜色帧文件夹./DeOldify/video/colorframes/my_video/是空的。

- 只是看看它是否会起作用; 取第一个黑白帧00001.jpg并将其放在./DeOldify/中,然后运行以下代码:

colorizer = get_image_colorizer(artistic=True)
source_url = '00001.jpg'
render_factor = 35

image_path = colorizer.plot_transformed_image(path=source_url, render_factor=render_factor, compare=True)

第一帧的彩色版本创建为./DeOldify/result_images/00001.jpg

视频命令的完整 output 错误:

>>> video_path = colorizer.colorize_from_file_name(source_url, 'video.mp4', render_factor)
ffmpeg version N-92462-g529debc987 Copyright (c) 2000-2018 the FFmpeg developers
  built with gcc 8.2.1 (GCC) 20181017
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --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
  libavutil      56. 23.101 / 56. 23.101
  libavcodec     58. 39.100 / 58. 39.100
  libavformat    58. 22.100 / 58. 22.100
  libavdevice    58.  6.100 / 58.  6.100
  libavfilter     7. 44.100 /  7. 44.100
  libswscale      5.  4.100 /  5.  4.100
  libswresample   3.  4.100 /  3.  4.100
  libpostproc    55.  4.100 / 55.  4.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'video\source\my_video.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf55.42.101
  Duration: 00:00:27.59, start: 0.000000, bitrate: 2636 kb/s
    Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 720x576, 2500 kb/s, 50 fps, 50 tbr, 12800 tbn, 100 tbc (default)
    Metadata:
      handler_name    : VideoHandler
    Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 128 kb/s (default)
    Metadata:
      handler_name    : SoundHandler
Please use -q:a or -q:v, -qscale is ambiguous
Stream mapping:
  Stream #0:0 -> #0:0 (h264 (native) -> mjpeg (native))
    Press [q] to stop, [?] for help
    [swscaler @ 0000025261e16f80] deprecated pixel format used, make sure you did set range correctly
Output #0, image2, to 'video\bwframes\my_video\%5d.jpg':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf58.22.100
    Stream #0:0(und): Video: mjpeg, yuvj420p(pc), 720x576, q=2-31, 200 kb/s, 50 fps, 50 tbn, 50 tbc (default)
    Metadata:
      handler_name    : VideoHandler
      encoder         : Lavc58.39.100 mjpeg
    Side data:
      cpb: bitrate max/min/avg: 0/0/200000 buffer size: 0 vbv_delay: -1
frame= 1378 fps=499 q=0.0 Lsize=N/A time=00:00:27.56 bitrate=N/A speed=9.99x
video:75662kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: unknown
Traceback (most recent call last):----------------------------| 0.00% [0/1378 00:00<00:00]
  File "<stdin>", line 1, in <module>
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 347, in colorize_from_file_name
    return self._colorize_from_path(
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 359, in _colorize_from_path
    self._colorize_raw_frames(
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 273, in _colorize_raw_frames
    color_image = self.vis.get_transformed_image(
  File "C:\python-virtual-environments\DeOldify\deoldify\visualize.py", line 178, in get_transformed_image
    filtered_image = self.filter.filter(
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 121, in filter
    filtered_image = filter.filter(orig_image, filtered_image, render_factor, post_process)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 83, in filter
    model_image = self._model_process(orig=filtered_image, sz=render_sz)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 45, in _model_process
    model_image = self._get_model_ready_image(orig, sz)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 40, in _get_model_ready_image
    result = self._scale_to_square(orig, sz)
  File "C:\python-virtual-environments\DeOldify\deoldify\filters.py", line 37, in _scale_to_square
    return orig.resize(targ_sz, resample=PIL.Image.BILINEAR)
  File "C:\python-virtual-environments\lib\site-packages\PIL\Image.py", line 1943, in resize
    return self._new(self.im.resize(size, resample, box))
TypeError: an integer is required (got type str)

这是否意味着应该是 int 的字符串出现在 /DeOldify/deoldify/filters.py 的第 347 行或 /lib/site-packages/PIL/Image.py 的第 1943 行

这意味着filters.py中的某些内容负责使用Image.py中引发TypeError的某些内容。

考虑一个简单的例子,让zerodiv.py内容为:

def f():
    return 1/0
def g():
    return f()
def h():
    return g()
print(h())

然后

python zerodiv.py

将给出以下 output

Traceback (most recent call last):
  File "zerodiv.py", line 7, in <module>
    print(h())
  File "zerodiv.py", line 6, in h
    return g()
  File "zerodiv.py", line 4, in g
    return f()
  File "zerodiv.py", line 2, in f
    return 1/0
ZeroDivisionError: division by zero

如您所见,是导致错误的行为过程。 如果您想了解有关 python 回溯的更多信息,我建议阅读realpython.com 教程 - 了解 Python 回溯

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM