AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1829765
Accepted
Life is complex
Life is complex
Asked: 2024-02-11 22:55:20 +0800 CST2024-02-11 22:55:20 +0800 CST 2024-02-11 22:55:20 +0800 CST

使用 ffmpeg 分析 AVI 音频

  • 772

我刚开始使用ffmpeg. 我有一些 AVI 文件,我认为应该有音频,但我无法使用 VLC 播放音频。我尝试使用它ffmpeg来分析 AVI 文件的音频。

import subprocess

def has_audio(filename):
    result = subprocess.run(["ffprobe", "-v", "error", "-show_entries",
                             "format=nb_streams", "-of",
                             "default=noprint_wrappers=1:nokey=1", filename],
        stdout=subprocess.PIPE,
        stderr=subprocess.STDOUT)
    return int(result.stdout) -1

print(has_audio('filename.avi'))

下面是其中一个 AVI 文件的输出。该文件看起来有音频,但也许我错误地读取了输出。我还尝试了这个问题中的代码,它告诉我视频有音频。

如何使用任一或其他应用程序确保该文件有音频或没有音频ffmpeg?

avi @ 0x7fddac005140] non-interleaved AVI
Guessed Channel Layout for Input Stream #0.1 : mono
Input #0, avi, from 'filename.avi':
  Metadata:
    date            : 2010-06-29
  Duration: 00:00:06.83, start: 0.000000, bitrate: 10607 kb/s
  Stream #0:0: Video: mjpeg (Baseline) (MJPG / 0x47504A4D), yuvj420p(pc, bt470bg/unknown/unknown), 1920x1080, 9878 kb/s, 30 fps, 30 tbr, 30 tbn
  Stream #0:1: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 32000 Hz, 1 channels, s16, 512 kb/s
Stream mapping:
  Stream #0:1 -> #0:0 (pcm_s16le (native) -> pcm_s16le (native))
Press [q] to stop, [?] for help
Output #0, null, to 'pipe:':
  Metadata:
    date            : 2010-06-29
    encoder         : Lavf60.3.100
  Stream #0:0: Audio: pcm_s16le, 32000 Hz, mono, s16, 512 kb/s
    Metadata:
      encoder         : Lavc60.3.100 pcm_s16le
size=N/A time=00:00:05.99 bitrate=N/A speed=1.52e+03x       
video:0kB audio:375kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: unknown
[Parsed_volumedetect_0 @ 0x7fdd9b704080] n_samples: 192000
[Parsed_volumedetect_0 @ 0x7fdd9b704080] mean_volume: -44.3 dB
[Parsed_volumedetect_0 @ 0x7fdd9b704080] max_volume: -16.2 dB
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_16db: 3
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_17db: 0
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_18db: 9
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_19db: 9
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_20db: 15
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_21db: 16
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_22db: 12
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_23db: 25
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_24db: 19
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_25db: 25
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_26db: 22
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_27db: 13
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_28db: 17
[Parsed_volumedetect_0 @ 0x7fdd9b704080] histogram_29db: 13

这是输出MediaInfo

Bit rate: 12884197, Frame rate: 30.000, Format: JPEG
Duration (raw value): 6833
Duration (other values:
['6 s 833 ms',
 '6 s 833 ms',
 '6 s 833 ms',
 '00:00:06.833',
 '00:00:06:25',
 '00:00:06.833 (00:00:06:25)']
Track data:
{'alignment': 'Aligned',
 'bit_depth': 16,
 'bit_rate': 512000,
 'bit_rate_mode': 'CBR',
 'channel_s': 1,
 'codec_id': '1',
 'codec_id_url': 'http://www.microsoft.com/windows/',
 'commercial_name': 'PCM',
 'count': '285',
 'count_of_stream_of_this_kind': '1',
 'delay': 0,
 'delay__origin': 'Stream',
 'delay_relative_to_video': 0,
 'duration': 6000,
 'format': 'PCM',
 'format_settings': 'Little / Signed',
 'format_settings__endianness': 'Little',
 'format_settings__sign': 'Signed',
 'interleave__duration': 1139,
 'kind_of_stream': 'Audio',
 'other_alignment': ['Aligned on interleaves'],
 'other_bit_depth': ['16 bits'],
 'other_bit_rate': ['512 kb/s'],
 'other_bit_rate_mode': ['Constant'],
 'other_channel_s': ['1 channel'],
 'other_delay': ['00:00:00.000', '00:00:00.000'],
 'other_delay__origin': ['Raw stream'],
 'other_delay_relative_to_video': ['00:00:00.000', '00:00:00.000'],
 'other_duration': ['6 s 0 ms',
                    '6 s 0 ms',
                    '6 s 0 ms',
                    '00:00:06.000',
                    '00:00:06.000'],
 'other_format': ['PCM'],
 'other_interleave__duration': ['1139',
                                '1139  ms (34.17 video frames)',
                                '34.17'],
 'other_kind_of_stream': ['Audio'],
 'other_sampling_rate': ['32.0 kHz'],
 'other_stream_size': ['375 KiB (4%)',
                       '375 KiB',
                       '375 KiB',
                       '375 KiB',
                       '375.0 KiB',
                       '375 KiB (4%)'],
 'other_track_id': ['1'],
 'proportion_of_this_stream': '0.04238',
 'samples_count': '192000',
 'sampling_rate': 32000,
 'stream_identifier': '0',
 'stream_size': 384000,
 'streamorder': '1',
 'track_id': 1,
 'track_type': 'Audio'}
audio
  • 2 2 个回答
  • 67 Views

2 个回答

  • Voted
  1. harrymc
    2024-02-11T23:07:44+08:002024-02-11T23:07:44+08:00

    您的输出显示该文件有音频:

      Stream #0:1: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 32000 Hz, 1 channels, s16, 512 kb/s
    
    • 1
  2. Best Answer
    JayCravens
    2024-02-11T23:19:06+08:002024-02-11T23:19:06+08:00

    尝试这个:

    ffmpeg -i filename.avi -c:v copy -c:a aac file_pcm_to_aac.mp4
    

    这将使视频保持原样,但将 PCM WAV 编码为 m4a AAC。

    如果这不起作用:

    ffmpeg -i filename.avi -an -c:v copy file_video_only.mp4 && ffmpeg -i filename.avi -vn filename_audio_only.wav
    

    然后看看它是否会以 wav 文件的形式单独播放aplay。如果没有,请尝试打开它,audacity看看是否可以打开。如果audacity无法打开它,请尝试将其转储为原始文件,并指定输入类型。

    ffmpeg -f s16le -i filename_audio_only.wav -c:a pcm_s16le output.wav
    

    然后尝试从 RAW 导入它,指定它是有符号的、16 位、小端、32000 Hz、单声道到audacity.


    可能有什么事情要做[avi @ 0x5617e27c4cc0] non-interleaved AVI。
    这就是说,“帧速率必须能被音频采样率整除”。

    AviSynth 或许能够使用 DirectShow 来专门定位音频。

    从上面的帖子:

    现在,如果我在另一个 AVI 中“重新编码”该文件:

    ffmpeg -i f.avi -c copy f2.avi
    

    我可以在几毫秒内从 f2.avi 中提取音频!

    .avi首先尝试转换为交错是最容易的。


    我已经尝试过它并且我很确定音频会转换。该剪辑只有半秒的麦克风碰撞,所以我不确定。它需要在更长的文件上进行测试。

    当源视频从奇怪的 PCM 轨道中正确解复用后,可以在容器305K中正常播放mkv。这就留下了音频。WAV 文件很大,所以这是有道理的。提取的变化范围从2.4mb 到 3.0mb ...如果不-f sle16引导输入.avi文件,它会提取大约 400k 的东西,这是完全错误的。

    ├── [ 2.4M]  audio_file.wav
    ├── [ 3.3M]  MOVI0000.avi
    ├── [ 305K]  MOVI0000.mkv
    

    -c copy或之间没有区别-c:a pcm_s16le,文件大小为 2.4mb+(PCM 未压缩,因此除非您更改频道、频率或比特率,否则它是多余的。)

    这将正确转换视频:

     ffmpeg -fflags +genpts -i MOVI0000.avi -vf "format=yuv420p" -c:v libx264 -x264opts b-pyramid=normal -g 120 -preset veryslow -b:v 500K -maxrate:v 4M -bufsize 8M -rc-lookahead 60 -refs 3 -bf 2 -b_strategy 2 -subq 11 -mixed-refs 1 -8x8dct 1 -partitions all -direct-pred auto -nal-hrd vbr -aq-mode autovariance -aq-strength 1.1 -trellis 2 -c:a aac -ac 1 -b:a 128k MOVI0000.mkv
    

    如果音频无法正确转换,只需替换-c:a aac -ac 1 -b:a 128k为-an即可消除它。

    • 1

相关问题

  • audioSprite / ffmpeg 中的单声道音频与立体声具有相同的比特率

  • 蓝牙设备 Bose Soundlink Revolve 烦人地在 Windows 10 启动时自动打开

  • 如何使用 FFmpeg 获得最终的 LUF 值?

  • 最低比特率 ffmpeg 输出的编解码器和设置

  • 索尼WH-1000XMX2蓝牙耳机无法自动正确连接

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    Vickel Firefox 不再允许粘贴到 WhatsApp 网页中? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve