Fixed: Computing most common author now we have multiple authors

pull/1151/head
ta264 4 years ago
parent 85e945430b
commit b1e92e7f73

@ -285,7 +285,13 @@ namespace NzbDrone.Core.MediaFiles.BookImport.Identification
}
else
{
authorTags.AddRange(localEdition.LocalBooks.MostCommon(x => x.FileTrackInfo.Authors));
// the most common list of authors reported by a file
var authors = localEdition.LocalBooks.Select(x => x.FileTrackInfo.Authors.Where(a => a.IsNotNullOrWhiteSpace()).ToList())
.GroupBy(x => x.ConcatToString())
.OrderByDescending(x => x.Count())
.First()
.First();
authorTags.AddRange(authors);
}
var bookTag = localEdition.LocalBooks.MostCommon(x => x.FileTrackInfo.BookTitle) ?? "";

@ -23,19 +23,20 @@ namespace NzbDrone.Core.MediaFiles.BookImport.Identification
{
var dist = new Distance();
var authors = new List<string>();
// the most common list of authors reported by a file
var fileAuthors = localTracks.Select(x => x.FileTrackInfo.Authors.Where(a => a.IsNotNullOrWhiteSpace()).ToList())
.GroupBy(x => x.ConcatToString())
.OrderByDescending(x => x.Count())
.First()
.First();
var fileAuthors = localTracks.MostCommon(x => x.FileTrackInfo.Authors);
if (fileAuthors?.Any() ?? false)
{
authors.AddRange(fileAuthors);
var authors = new List<string>(fileAuthors);
foreach (var author in fileAuthors)
foreach (var author in fileAuthors)
{
if (author.Contains(','))
{
if (author.Contains(','))
{
authors.Add(authors[0].Split(',', 2).Select(x => x.Trim()).Reverse().ConcatToString(" "));
}
authors.Add(authors[0].Split(',', 2).Select(x => x.Trim()).Reverse().ConcatToString(" "));
}
}

Loading…
Cancel
Save