當前位置: 首頁>>代碼示例>>Python>>正文


Python mutagen.File方法代碼示例

本文整理匯總了Python中mutagen.File方法的典型用法代碼示例。如果您正苦於以下問題:Python mutagen.File方法的具體用法?Python mutagen.File怎麽用?Python mutagen.File使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在mutagen的用法示例。


在下文中一共展示了mutagen.File方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: main

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def main(argv):
    from mutagen import File

    parser = OptionParser()
    parser.add_option("--no-flac", help="Compatibility; does nothing.")
    parser.add_option("--no-mp3", help="Compatibility; does nothing.")
    parser.add_option("--no-apev2", help="Compatibility; does nothing.")

    (options, args) = parser.parse_args(argv[1:])
    if not args:
        raise SystemExit(parser.print_help() or 1)

    for filename in args:
        print_(u"--", filename)
        try:
            print_(u"-", File(filename).pprint())
        except AttributeError:
            print_(u"- Unknown file type")
        except Exception as err:
            print_(text_type(err))
        print_(u"") 
開發者ID:bugatsinho,項目名稱:bugatsinho.github.io,代碼行數:23,代碼來源:mutagen_inspect.py

示例2: is_partial

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def is_partial(audio_file, track):
    args = get_args()
    if (args.partial_check == "none"):
        return False

    def audio_file_duration(audio_file):
        if (path_exists(audio_file)):
            _file = mutagen.File(audio_file)
            if _file is not None and _file.info is not None:
                return _file.info.length
        return None

    audio_file_dur = audio_file_duration(audio_file)

    # for 'weak', give a ~1.5 second wiggle-room
    if (args.partial_check == "strict"):
        return (audio_file_dur is None or
            track.duration > (audio_file_dur * 1000))
    else:
        return (audio_file_dur is not None and
            (track.duration - 1500) > (audio_file_dur * 1000))


# borrowed from eyeD3 
開發者ID:hbashton,項目名稱:spotify-ripper,代碼行數:26,代碼來源:utils.py

示例3: embed_album_art

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def embed_album_art(cover_filepath, audio_filepaths):
  """ Embed album art into audio files. """
  with open(cover_filepath, "rb") as f:
    cover_data = f.read()

  for filepath in audio_filepaths:
    mf = mutagen.File(filepath)
    if (isinstance(mf.tags, mutagen._vorbis.VComment) or
            isinstance(mf, mutagen.ogg.OggFileType)):
      picture = mutagen.flac.Picture()
      picture.data = cover_data
      picture.type = mutagen.id3.PictureType.COVER_FRONT
      picture.mime = "image/jpeg"
      encoded_data = base64.b64encode(picture.write())
      mf["metadata_block_picture"] = encoded_data.decode("ascii")
    elif (isinstance(mf.tags, mutagen.id3.ID3) or
          isinstance(mf, mutagen.id3.ID3FileType)):
      mf.tags.add(mutagen.id3.APIC(mime="image/jpeg",
                                   type=mutagen.id3.PictureType.COVER_FRONT,
                                   data=cover_data))
    elif (isinstance(mf.tags, mutagen.mp4.MP4Tags) or
          isinstance(mf, mutagen.mp4.MP4)):
      mf["covr"] = [mutagen.mp4.MP4Cover(cover_data,
                                         imageformat=mutagen.mp4.AtomDataType.JPEG)]
    mf.save() 
開發者ID:desbma,項目名稱:sacad,代碼行數:27,代碼來源:recurse.py

示例4: removeAllTagsFromPath

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def removeAllTagsFromPath(path):
    # subprocess.check_output(['id3v2', '--delete-all', path])
    mutagenFile = mutagen.File(path)
    print(type(mutagenFile), path)

    if isinstance(mutagenFile, mutagen.flac.FLAC):
        mutagenFile.clear_pictures()
        mutagenFile.delete(path)
        # mutagenFile.save(path, deleteid3=True, padding=lambda x: 0)
        return
    elif isinstance(mutagenFile, mutagen.id3.ID3FileType):
        mutagenFile.delete(path)
        return
    elif isinstance(mutagenFile, mutagen.apev2.APEv2File):
        mutagenFile.delete(path)
        return

    mutagenFile.delete(path) 
開發者ID:antlarr,項目名稱:bard,代碼行數:20,代碼來源:utils.py

示例5: removeAllTags

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def removeAllTags(filelike, recurse=True):
    try:
        filelike.seek(0)
        id3 = mutagen.id3.ID3(filelike)
    except mutagen.id3._util.ID3NoHeaderError:
        pass
    else:
        filelike.seek(0)
        id3.delete(filelike)

    filelike.seek(0)
    mutagenFile = mutagen.File(filelike)
    # print(type(mutagenFile), filelike.name)

    if isinstance(mutagenFile, mutagen.flac.FLAC) and mutagenFile.pictures:
        mutagenFile.clear_pictures()
        filelike.seek(0)
        mutagenFile.save(filelike, padding=lambda x: 0)

    filelike.seek(0)
    if mutagenFile:
        mutagenFile.delete(filelike) 
開發者ID:antlarr,項目名稱:bard,代碼行數:24,代碼來源:utils.py

示例6: getCoverImage

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def getCoverImage(self):
        path = self.path()
        directory = os.path.dirname(path)
        for cover in ['cover.jpg', 'cover.png']:
            coverfilename = os.path.join(directory, cover)
            if os.path.exists(coverfilename):
                return coverfilename

        try:
            metadata = self.metadata
        except AttributeError:
            try:
                metadata = mutagen.File(path)
            except mutagen.mp3.HeaderNotFoundError as e:
                print("Error reading %s:" % path, e)
                return None

        try:
            image = extractFrontCover(metadata)
        except OSError:
            print('Error extracting image from %s' % path)
            return None

        return image 
開發者ID:antlarr,項目名稱:bard,代碼行數:26,代碼來源:song.py

示例7: fixMtime

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def fixMtime(self):
        collection = getMusic()
        count = 0
        for song in collection:
            if not song.mtime():
                try:
                    mtime = os.path.getmtime(song.path())
                except os.FileNotFoundError:
                    print('File %s not found: removing from db' % song.path())
                    MusicDatabase.removeSong(song)
                    continue

                if not config['immutableDatabase']:
                    c = MusicDatabase.getCursor()
                    sql = text('UPDATE songs set mtime = :mtime '
                               'WHERE id = :id')
                    c.execute(sql.bindparams(mtime=mtime, id=song.id))
                    count += 1
                    if count % 10:
                        MusicDatabase.commit()
                print('Fixed %s' % song.path())
            else:
                print('%s already fixed' % song.path())
        MusicDatabase.commit() 
開發者ID:antlarr,項目名稱:bard,代碼行數:26,代碼來源:bard.py

示例8: add_metadata

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def add_metadata(self, file, sound):
        # "sound" requires a "freesound_client.get_sound" object
        # http://wiki.hydrogenaud.io/index.php?title=APE_key
        try:
            # Write it
            audio = FLAC(file)
            audio["title"] = sound.name
            audio["Artist"] = sound.username
            audio["Comment"] = sound.description
            audio["Publisher"] = "freesound.org"
            audio["File"] = sound.url
            # Save it
            audio.pprint()
            audio.save()
            # Read it
            file_info = mutagen.File(file)
            log.debug("Result metadata update:")
            log.debug(file_info)
            return file_info
        except Exception as e:
            log.debug(e)
            return False 
開發者ID:Fr6jDJF,項目名稱:Mash-Cogs,代碼行數:24,代碼來源:freesound.py

示例9: get_audio_length

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def get_audio_length(path):
    try:
        audio = MutagenFile(path, FORMATS)
        if audio is not None:
            return int(audio.info.length) * 1000
        return 0
    except:
        return 0 
開發者ID:dragondjf,項目名稱:QMusic,代碼行數:10,代碼來源:common.py

示例10: get_audio_length

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def get_audio_length(path):        
    try:
        audio = MutagenFile(path, FORMATS)
        if audio is not None:
            return int(audio.info.length) * 1000
        return 0
    except:
        return 0 
開發者ID:dragondjf,項目名稱:QMusic,代碼行數:10,代碼來源:common.py

示例11: test_add_album_art

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def test_add_album_art():

    musictools.add_album_art(location, albumart)
    tags = File(location)
 
    assert 'APIC:Cover' in tags.keys() != None 
開發者ID:kalbhor,項目名稱:MusicTools,代碼行數:8,代碼來源:musictools_tests.py

示例12: _add_audio_length_on_file

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def _add_audio_length_on_file(audio_file, text, _length):
        file = mutagen.File(audio_file)
        try:
            length = file.info.length
        except AttributeError:
            # In case the type was not recognized by mutagen
            logging.warning("Audio file incorrect : %s", audio_file)
            length = 0
        return [audio_file, text, length] 
開發者ID:inikdom,項目名稱:rnn-speech,代碼行數:11,代碼來源:dataprocessor.py

示例13: initialize

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def initialize(file):
        audio = mutagen.File(file)
        if (isinstance(audio, MP4)):
            return mp4Editor(file)
        if (isinstance(audio, MP3)):
            return mp3Editor(file) 
開發者ID:LXG-Shadow,項目名稱:BilibiliTools,代碼行數:8,代碼來源:infoEditor.py

示例14: get_filelist

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def get_filelist(self, src_dir):
		res = {}
		for f in sorted(os.listdir(src_dir)):
			fpath = join(src_dir, f)
			fname = f[:-4]
			fext = f[-4:].lower()
			if isfile(fpath) and fext in ('.wav', '.mp3', '.ogg'):
				if fname in res:
					if fext=='.wav':
						res[fname]['ext'] = fext
					elif fext=='.ogg' and res[fname]['ext']!='.wav':
						res[fname]['ext'] = fext
				else:	
					res[fname] = {
						'fpath': fpath,
						'ext': fext
					}

		for fname in res:
			try:
				res[fname]['length'] = mutagen.File(res[fname]['fpath']).info.length
			except Exception as e:
				res[fname]['length'] = 0
				logging.warning(e)

		return res 
開發者ID:zynthian,項目名稱:zynthian-ui,代碼行數:28,代碼來源:zynthian_gui_audio_recorder.py

示例15: checkSongsExistenceInPath

# 需要導入模塊: import mutagen [as 別名]
# 或者: from mutagen import File [as 別名]
def checkSongsExistenceInPath(self, song, callback=None):
        if not os.path.exists(song.path()):
            if os.path.lexists(song.path()):
                print('Broken symlink at %s' % song.path())
            else:
                print('File not found: %s' % song.path())

                if callback:
                    callback(song) 
開發者ID:antlarr,項目名稱:bard,代碼行數:11,代碼來源:bard.py


注:本文中的mutagen.File方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。