I’m looking for a free GUI that can download a YouTube channel in a particular language (i.e. Japanese) with it’s associated English subtitles preferably in SRT format.

I used 4K Video Downloader which worked fine for the “old” YT even though it was limited and I had to uninstall and reinstall a few times I got exactly what I wanted.

Then Google in all their stupidity decided to put all streams for a single video together so I can’t get what I want from 4K without downloading the video and then splitting the stream some way and downloading the Japanese audio to go with it.

Can anyone give me a simpler alternative to what I’m trying to do? I would appreciate any constructive input. Thanks!

  • Rodrigo_de_Mendoza@lemmy.dbzer0.comOP
    link
    fedilink
    English
    arrow-up
    1
    ·
    1 year ago

    Thanks for all the information!

    4K Video Downloader can download the “old” format of YT videos where a channel is strictly a particular language and put it in an MKV container with the resolution I select & an SRT subtitle using a VP9 codec & that’s fine. I just run it through my video converter and I’m good. The problem is when I try to download from one of the “new” multi-audio/sub channels. (Ugh!)

    Ok, so now let me see if I can answer your questions:
    Q1 - Yes, I mean a channel with multiple audio tracks but I can only access the English version although I know there’s a Japanese track there also.
    Q2 - The subtitle is the one you get by selecting CC on the YT control panel. I can see it with IDM but it’s in TIML format. 4K gives me a SRT on the “old” channels.
    Q3 - Yes, when I download I want a pre-merged file with the appropriate streams (Video, Japanese Audio & English Subtitles) preferably with an SRT sub.

    I hope that made sense. I’ve tried Tartube a bit but like you said it will still be the problem I run into with 4K Downloader, I can’t get the original Japanese audio. I can go to YouTube 4k Downloader and enter the URL for the file and download the Japanese audio and remux the file but when you’re talking about >100 files that’s a long process.

    Again, thank you for the information and explantion of the command line. I’m not very good with command line stuff but I will try it and see if I can get it work for me. Please feel free to comment back.

    • AernaLingus [any]@hexbear.net
      link
      fedilink
      English
      arrow-up
      3
      ·
      edit-2
      1 year ago

      Okay, Tartube can definitely handle what you want with a few additional flags! Here’s the mediainfo for the output file after doing a test run on this MrBeast video (note that the audio track is incorrectly marked as English but is indeed Japanese, and that S_TEXT is how SRT appears in an MKV file):

      mediainfo
      General
      Unique ID                                : 242275721910232180380466434100717751726 (0xB6449B54C970D7DBA0EB469BBD590DAE)
      Complete name                            : C:\Users\WDAGUtilityAccount\Tartube\Test Audio Playlist\$1 vs $100,000,000 House!.mkv
      Format                                   : Matroska
      Format version                           : Version 4
      File size                                : 556 MiB
      Duration                                 : 17 min 35 s
      Overall bit rate                         : 4 418 kb/s
      Frame rate                               : 29.970 FPS
      Writing application                      : Lavf60.3.100
      Writing library                          : Lavf60.3.100
      ErrorDetectionType                       : Per level 1
      
      Video
      ID                                       : 1
      Format                                   : VP9
      Format profile                           : 0
      Codec ID                                 : V_VP9
      Duration                                 : 17 min 35 s
      Width                                    : 1 920 pixels
      Height                                   : 1 080 pixels
      Display aspect ratio                     : 16:9
      Frame rate mode                          : Constant
      Frame rate                               : 29.970 (29970/1000) FPS
      Color space                              : YUV
      Chroma subsampling                       : 4:2:0
      Bit depth                                : 8 bits
      Title                                    : ISO Media file produced by Google Inc. Created on: 11/09/2023.
      Default                                  : Yes
      Forced                                   : No
      Color range                              : Limited
      Color primaries                          : BT.709
      Transfer characteristics                 : BT.709
      Matrix coefficients                      : BT.709
      VENDOR_ID                                : [0][0][0][0]
      
      Audio
      ID                                       : 2
      Format                                   : Opus
      Codec ID                                 : A_OPUS
      Duration                                 : 17 min 35 s
      Channel(s)                               : 2 channels
      Channel layout                           : L R
      Sampling rate                            : 48.0 kHz
      Bit depth                                : 32 bits
      Compression mode                         : Lossy
      Delay relative to video                  : 7 ms
      Language                                 : English
      Default                                  : Yes
      Forced                                   : No
      
      Text
      ID                                       : 3
      Format                                   : UTF-8
      Codec ID                                 : S_TEXT/UTF8
      Codec ID/Info                            : UTF-8 Plain Text
      Duration                                 : 17 min 30 s
      Language                                 : English
      Default                                  : No
      Forced                                   : No
      

      I did this all on Windows 10 in Windows Sandbox with a fresh Tartube install to make sure I didn’t have some lurking non-default setting causing unexplained behavior. Here’s what to do to get the same results, along with a screen recording of the same process with some rough edits (don’t be scared off by the long instructions–it’s mostly me just explaining what the options do, and it should only take about five to ten minutes!):

      1. Grab the 64-bit Windows installer here

      2. Go through the install process leaving everything as default and installing yt-dlp and FFmpeg when prompted

      3. Go through the tutorial just to get a sense of how things are laid out (it’s a lot to take in so don’t expect to remember everything, and I’m going to guide you through the exact steps do don’t worry)

      4. Add your channel by first copying the /videos URL (e.g. https://youtube.com/@MrBeast/videos), clicking the Add channel icon (second from the left in the toolbar), and entering the channel name (this will be the name of the folder that videos are stored in). If the URL isn’t automatically grabbed, paste it into the second box.

      5. Right-click the channel in the left-hand menu and select Downloads -> Apply download options

      6. Make sure Create new download options is selected and click OK

      7. (Optional) Give the options a sensible name, e.g. “Japanese Audio with embedded English SRT”

      8. Paste these options into the Additional download options box:

      
      --format bv*+ba[language=ja]/bv*+ba[language=en]/bv*+ba/best
      --convert-subs srt
      --compat-options no-keep-subs
      

      Explanation of the options:
      --convert-subs is pretty self explanatory–it will convert the YouTube VTT subs to SRT.
      --format: the format selection is a hierarchy delineated by the /. First, it tries to download the best video with the best audio in Japanese (bv*+ba[language=ja]). If Japanese audio isn’t present, it tries English audio (bv*+ba[language=en]). If neither are present (which can also happen if the uploader failed to mark the language correctly), it grabs whatever the default audio track is. If all else fails, it grabs the best combined format (this should realistically never happen on YouTube). If you dislike any of those fallback options and/or would prefer that the download simply fail, feel free to delete any/all of them along with the preceding /, although I recommend at least leaving bv*+ba. For your use case, --format bv*+ba[language=ja] is the bare minimum which will fail if there isn’t an audio track explicitly labeled as Japanese.)
      --compat-options no-keep-subs is necessary to make sure the subtitles are deleted after merging them into the MKV, since the options we will be setting through the GUI include both --write-subs and --embed-subs, and the default behavior in this scenario is to both embed the subs and write them to an external file. If you prefer to keep the external SRT file, simply remove this line.

      1. (Optional) Click the Files tab at the top and customize the filename format. Personally, I’m partial to
        %(upload_date)s %(title)s-%(id)s.%(ext)s
        so that I can naturally sort things by upload date and easily go between URLs and videos (since YouTube URLs are just https://youtube.com/watch?v=[id]), but if you’re happy with the default title-only you can leave this be.

      2. Click the Formats tab at the top. Set the drop-down for If merge is required after post-processing, output this format: to mkv. It will give you a warning that you need to also add it above, but as far as I can tell this is neither true (works fine without it) nor possible (mkv isn’t even listed there). If you do prefer specific video/audio formats or want a specific/maximum resolution, let me know and I can change the format option to accommodate that preference, since unfortunately this tab doesn’t account for multiple audio tracks.

      3. Click the Subtitles tab at the top. Ensure that Download subtitle file for these languages: is selected and that English [en] is listed (if your default Windows language is English I think it’ll already be there, but if not, add it from the list on the left). Note that this will not grab the automatically-generated subtitles from YouTube, but it sounds like you don’t need these for your specific situation.

      4. Click the More options sub-tab. Under Preferred subtitle formats write srt/best (I honestly don’t think this will affect YouTube since all subs seem to be VTT, but it can’t hurt). More importantly, check the box for During post-processing, merge subtitles file with video.

      5. Click OK in the lower-right to save the download options. You’re done with the setup!

       

      If you want to download the entire channel in this way, right-click the channel in the left-hand menu and click Download channel. You can monitor the download progress in the Progress tab and see the raw yt-dlp command line output in the Output tab. If you only want certain videos, instead choose Check channel. This will grab all the metadata for the channel’s videos, displaying them as a grid of thumbnails, and then you can select them through the GUI and download the specific ones you want. It also might be a good idea to do this if you want to test the options on one video to make sure you’re getting the result you want before going all-in on downloading the channel.

      Looking over the yt-dlp output as a sanity-check, I can confirm it does the following things:

      1. Writes en.vtt subtitles (English subtitles in the default YouTube format)

      2. Selects the best video format (1080p VP9)

      3. Selects the audio format 251-1 (which is the best Japanese audio on this particular video)

      4. Converts subtitles to SRT

      5. Merges all three tracks into MKV

      6. Deletes external SRT

      which I think is all the functionality you requested! Let me know if you have any further questions and I’ll do my best to answer them.

      • Rodrigo_de_Mendoza@lemmy.dbzer0.comOP
        link
        fedilink
        English
        arrow-up
        3
        ·
        edit-2
        1 year ago

        I’ve tested the process in a single & multi-language channel and a single video & it worked for perfectly for all.

        Several questions I have:

        1 - When I installed Tartube, my Antivirus told me the gslangValidator.exe file was infected by Win64: Evo-gen [Trj] and quarantined it. Any idea why?

        2 - How do I get rid of all the other files like jpeg, txt, json etc. files or are they supposed to be there.

        3 - Supposing I wanted a 360p resolution downloaded, what would have to be changed in the format options?

        I’m really amazed at this and hope to learn more about Tartube. Thank you very much for your time in putting all this together & I look forward to further correspondence!

        • AernaLingus [any]@hexbear.net
          link
          fedilink
          English
          arrow-up
          2
          arrow-down
          1
          ·
          edit-2
          1 year ago

          Great, I’m so glad to hear that! Tartube can be a little intimidating with it’s sprawling menus and sub-menus, but when it comes down to it most of the core functionality is pretty accessible once you know where to look and can ignore all the hyper-specific options for power users.

          1. No idea, to be honest. In the environment I tested this in (Windows 10 Sandbox) Windows Defender didn’t complain, and I’ve never had an issue with my actual install either. In fact, I just checked my installation folders on my PC and didn’t even find that executable (maybe it’s only used during installation?) although I do have it on my system for a different program. I only found one Google hit from 5 years ago on the glslang Github itself, and the user seemed to think it was a false positive for what it’s worth.

          2. They are supposed to be there by default (they store metadata) but you can set up Tartube to put them in separate folders if you want to just have a nice clean folder with only videos or just not write them in the first place if you don’t want them. I believe the metadata is copied into Tartube’s database, so deleting them shouldn’t change anything (they’re mostly useful for archival purposes or if you want to do some processing with external tools), but Tartube references the thumbnail image files for display in the GUI so removing them will remove the thumbnail from the GUI like so:

          This is pretty straightforward to configure, thankfully:

          1. Right-click the desired menu in the left-hand menu and select Downloads -> Edit download options…; this will bring up the same dialog we were using before, but we are just editing our existing profile instead of creating a new one.
          2. Click the Files tab, then the Write/move sub-tab.
          3. Here you’ll see options to instruct Tartube to move each of the file types to a separate folder and/or not write them in the first place. Select whichever options suit your preferences and then click OK.

           

          3. (hosted externally due to Lemmy sanitization bug causing less-than symbols to be HTML escaped)

          edit: accidentally left out a line in the externally hosted markdown

          • Rodrigo_de_Mendoza@lemmy.dbzer0.comOP
            link
            fedilink
            English
            arrow-up
            1
            ·
            edit-2
            1 year ago

            I agree that file is probably just a false positive. I deleted it from quarantine and it didn’t affect the program at all.

            You are absolutely THE BEST!!! I appreciate all your hard work so much. This saves me sooo much time and is so helpful! I cannot thank you enough.