Каков наилучший способ получить информацию CDDB для аудио компакт-диска на Perl?

StackOverflow https://stackoverflow.com/questions/2264723

  •  20-09-2019
  •  | 
  •  

Вопрос

Каков наилучший способ получить название компакт-диска и названия дорожек компакт-диска с аудио компакт-диска?Я попробовал этот модуль, но он не сработал.

#!/usr/bin/env perl
use warnings;
use strict;
use CDDB_get qw( get_cddb );

my %config;
$config{CDDB_HOST} = "freedb.freedb.org";
$config{CDDB_PORT} = 8880;
$config{CDDB_MODE} = "cddb";
$config{CD_DEVICE} = "/dev/sr1";

# user interaction welcome?
$config{input} = 1;

my %cd = get_cddb( \%config ); # line 16

print "$_ : $cd{$_}\n" for keys %cd;

unless( defined $cd{title} ) {
    die "no cddb entry found";
}

print "artist: $cd{artist}\n";
print "title: $cd{title}\n";
print "category: $cd{cat}\n";
print "cddbid: $cd{id}\n";
print "trackno: $cd{tno}\n";

my $n = 1;
for my $i ( @{$cd{track}} ) {
    print "track $n: $i\n";
    $n++;
}

# OUT:
# Odd number of elements in hash assignment at ./cddb_get.pl line 16.
# Use of uninitialized value in list assignment at ./cddb_get.pl line 16.
# Use of uninitialized value in concatenation (.) or string at ./cddb_get.pl line 18.
#  :
# no cddb entry found at ./cddb_get.pl line 21.
Это было полезно?

Решение

Попробуйте положить

BEGIN { $CDDB_get::debug = 1 }

перед тем, как use CDDB_get строка для того, чтобы получить отладочный вывод в STDERR.

Другие советы

Вы уверены, что URL API для FreeDB указан в модуле правильно?

Можете ли вы попробовать HTTP вместо CDDBP?

От документация FreeDB:

Настройте свой CDDB1- или freedb-aware программное обеспечение так, чтобы оно указывало на freedb.freedb.org (Случайный freedb-сервер) в качестве вашего CDDB/freedb-сервера.

Все официальные серверы freedb работают под управлением cddbp на порту 8880 и http на порту 80.Путь для http-доступа - это /~cddb/cddb.cgi.

Я бы подумал о том, чтобы поискать информацию по musicbrainz.org вместо этого.

Использовать MusicBrainz::DiscId для поиска discid компакт-диска и WebService::MusicBrainz для извлечения данных довольно просто:

#!/usr/bin/perl

use strict;
use warnings;

use MusicBrainz::DiscID;
use WebService::MusicBrainz;

my $discid=MusicBrainz::DiscID->new;
if ( !$discid->read ) {
    print STDERR "Error: " . $discid->error_msg . "\n";
    exit 1;
}
print "DiscID: " . $discid->id . "\n";

my $service=WebService::MusicBrainz->new_release;
my $response=$service->search({ DISCID=>$discid->id });
my $release=$response->release;

print "ARTIST: " . $release->artist->name . "\n";
print "ALBUM:  " . $release->title . "\n";
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top