Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
4f29b5c778 | |||
5a57469f1c | |||
1d98c876c3 | |||
f9a9d36bd8 | |||
308f680a87 | |||
a43e6fb57f | |||
ceceb69b3f |
@ -88,7 +88,15 @@ namespace Txt2Bib
|
||||
|
||||
private void GoBtn_Click(object sender, RoutedEventArgs e)
|
||||
{
|
||||
Execute();
|
||||
try
|
||||
{
|
||||
Execute();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
MessageBox.Show($"Errore di esecuzione: {ex.Message}");
|
||||
return;
|
||||
}
|
||||
MessageBox.Show("File BibTeX generato correttamente.", "Success", MessageBoxButton.OK, MessageBoxImage.Information);
|
||||
}
|
||||
|
||||
|
124
Records.cs
124
Records.cs
@ -11,15 +11,27 @@ namespace Txt2Bib.Records
|
||||
|
||||
public abstract record ItemType
|
||||
{
|
||||
public string Pages { get; set; } = "";
|
||||
|
||||
protected static bool IsDoi(string url)
|
||||
{
|
||||
return url.Contains("doi");
|
||||
}
|
||||
protected static string Rearrange(string a)
|
||||
{
|
||||
a = a.Trim();
|
||||
var s = a.Split(' ');
|
||||
return $"{s[1]} {s[0]}";
|
||||
a = a.Trim();
|
||||
var s = a.Split(' ');
|
||||
return s.Length > 1 ?
|
||||
$"{s[1]} {s[0][0]}{s[0][1..].ToLower()}" : a;
|
||||
}
|
||||
|
||||
protected string CreatePages(string pages)
|
||||
{
|
||||
if (pages.Length == 0) { return ""; }
|
||||
|
||||
return pages.Split('-').Length == 2 ?
|
||||
$"{pages.Split('-')[0]}--{pages.Split('-')[1].TrimEnd('.')}" :
|
||||
pages;
|
||||
}
|
||||
}
|
||||
|
||||
@ -32,8 +44,6 @@ namespace Txt2Bib.Records
|
||||
public ushort Year { get; set; } = 1950;
|
||||
public string Volume { get; set; } = "";
|
||||
public string? Issue { get; set; } = null;
|
||||
public ushort FirstPage { get; set; } = 1;
|
||||
public ushort LastPage { get; set; } = 1;
|
||||
public string Doi { get; set; } = "";
|
||||
public string Url { get; set; } = "";
|
||||
|
||||
@ -49,15 +59,7 @@ namespace Txt2Bib.Records
|
||||
Volume = entryLines[5] != string.Empty ? checkVol(entryLines[5]) : Volume;
|
||||
Issue = entryLines[5].Split(',').Length == 2 ?
|
||||
entryLines[5].Split(',')[1].Trim() : Issue;
|
||||
try
|
||||
{
|
||||
FirstPage = ushort.Parse(entryLines[6].Split('-')[0]);
|
||||
LastPage = ushort.Parse(entryLines[6].Split('-')[1].TrimEnd('.'));
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
Pages = CreatePages(entryLines[6]);
|
||||
|
||||
if (entryLines.Length > 7 )
|
||||
{
|
||||
@ -70,14 +72,14 @@ namespace Txt2Bib.Records
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
return $"@{Type}{{{Author[0][..5].Replace(". ", "_")}_{Year},\n" +
|
||||
return $"@{Type}{{{Author[0][..2].Replace(". ", "_")}_{Year},\n" +
|
||||
$"\tauthor = \"{string.Join(" and ", Author)}\",\n" +
|
||||
$"\ttitle = {{{Title}}},\n" +
|
||||
$"\tjournal = \"{Journal}\",\n" +
|
||||
$"\tyear = \"{Year}\",\n" +
|
||||
$"\tvolume = \"{Volume}\",\n" +
|
||||
$"\tnumber = \"{Issue}\",\n" +
|
||||
$"\tpages = \"{FirstPage}--{LastPage}\",\n" +
|
||||
$"\tpages = \"{Pages}\",\n" +
|
||||
$"\tdoi = \"{Doi}\",\n" +
|
||||
$"\turl = \"{Url}\",\n" +
|
||||
"}\n";
|
||||
@ -92,6 +94,7 @@ namespace Txt2Bib.Records
|
||||
public string Title { get; set; } = "";
|
||||
public ushort Year { get; set; } = 1950;
|
||||
public string Publisher { get; set; } = "";
|
||||
public string Series { get; set; } = "";
|
||||
public string Place { get; set; } = "";
|
||||
public string Url { get; set; } = "";
|
||||
public string Doi { get; set; } = "";
|
||||
@ -99,9 +102,9 @@ namespace Txt2Bib.Records
|
||||
public string Convert(string[] entryLines)
|
||||
{
|
||||
var auths = entryLines[1];
|
||||
if (auths.Contains("eds"))
|
||||
if (auths.Contains("ed"))
|
||||
{
|
||||
Editor = auths.Replace("(eds.)", "").Split(',').Select(a => Rearrange(a)).ToArray();
|
||||
Editor = Regex.Replace(auths,@"\(eds?\.\)", "").Split(',').Select(a => Rearrange(a)).ToArray();
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -109,13 +112,14 @@ namespace Txt2Bib.Records
|
||||
}
|
||||
Year = ushort.Parse(entryLines[2]);
|
||||
Title = entryLines[3];
|
||||
Place = entryLines[4];
|
||||
Publisher = entryLines[5];
|
||||
Series = entryLines[4] != string.Empty ? entryLines[4] : Series;
|
||||
Place = entryLines[5];
|
||||
Publisher = entryLines[6];
|
||||
|
||||
if (entryLines.Length > 6 )
|
||||
if (entryLines.Length > 7 )
|
||||
{
|
||||
if (IsDoi(entryLines[6])) Doi = entryLines[6];
|
||||
else Url = entryLines[6];
|
||||
if (IsDoi(entryLines[7])) Doi = entryLines[7];
|
||||
else Url = entryLines[7];
|
||||
}
|
||||
|
||||
return ToString();
|
||||
@ -128,12 +132,12 @@ namespace Txt2Bib.Records
|
||||
|
||||
if (Author.Length != 0)
|
||||
{
|
||||
label = Author[0][..5].Replace(". ", "");
|
||||
label = Author[0][..2].Replace(". ", "");
|
||||
authString = $"\tauthor = \"{string.Join(" and ", Author)}\",\n";
|
||||
}
|
||||
else
|
||||
{
|
||||
label = Editor[0][..5].Replace(". ", "");
|
||||
label = Editor[0][..2].Replace(". ", "");
|
||||
authString = $"\teditor = \"{string.Join(" and ", Editor)}\",\n";
|
||||
}
|
||||
|
||||
@ -141,6 +145,7 @@ namespace Txt2Bib.Records
|
||||
authString +
|
||||
$"\ttitle = {{{Title}}},\n" +
|
||||
$"\tpublisher = \"{Publisher}\",\n" +
|
||||
$"\tseries = \"{Series}\",\n" +
|
||||
$"\taddress = \"{Place}\",\n" +
|
||||
$"\tyear = \"{Year}\",\n" +
|
||||
$"\turl = \"{Url}\",\n" +
|
||||
@ -153,13 +158,13 @@ namespace Txt2Bib.Records
|
||||
{
|
||||
public string Type { get; init; } = "inproceedings";
|
||||
public string[] Author { get; set; } = Array.Empty<string>();
|
||||
public string[] Editor { get; set; } = Array.Empty<string>();
|
||||
public string Title { get; set; } = "";
|
||||
public string BookTitle { get; set; } = "";
|
||||
public ushort Year { get; set; } = 1950;
|
||||
public string Publisher { get; set; } = "";
|
||||
public string Series { get; set; } = "";
|
||||
public string Address { get; set; } = "";
|
||||
public ushort FirstPage { get; set; } = 1;
|
||||
public ushort LastPage { get; set; } = 1;
|
||||
public string Url { get; set; } = "";
|
||||
public string Doi { get; set; } = "";
|
||||
|
||||
@ -168,23 +173,19 @@ namespace Txt2Bib.Records
|
||||
Author = entryLines[1].Split(',').Select(a => Rearrange(a)).ToArray();
|
||||
Year = ushort.Parse(entryLines[2]);
|
||||
Title = entryLines[3];
|
||||
BookTitle = entryLines[4];
|
||||
Address = entryLines[5] != String.Empty ? entryLines[5] : Address;
|
||||
Publisher = entryLines[6];
|
||||
try
|
||||
{
|
||||
FirstPage = ushort.Parse(entryLines[7].Split('-')[0]);
|
||||
LastPage = ushort.Parse(entryLines[7].Split('-')[1].TrimEnd('.'));
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
Editor = entryLines[4] != String.Empty ?
|
||||
Regex.Replace(entryLines[4], @"\(eds?\.\)", "").Split(',').Select(a => Rearrange(a)).ToArray() :
|
||||
Editor;
|
||||
BookTitle = entryLines[5];
|
||||
Series = entryLines[6] != String.Empty ? entryLines[6] : Series;
|
||||
Address = entryLines[7] != String.Empty ? entryLines[7] : Address;
|
||||
Publisher = entryLines[8];
|
||||
Pages = CreatePages(entryLines[9]);
|
||||
|
||||
if (entryLines.Length > 8 )
|
||||
if (entryLines.Length > 10)
|
||||
{
|
||||
if (IsDoi(entryLines[8])) Doi = entryLines[8];
|
||||
else Url = entryLines[8];
|
||||
if (IsDoi(entryLines[10])) Doi = entryLines[10];
|
||||
else Url = entryLines[10];
|
||||
}
|
||||
|
||||
return ToString();
|
||||
@ -192,17 +193,21 @@ namespace Txt2Bib.Records
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
string label = Author[0][..5].Replace(". ", "");
|
||||
string label = Author[0][..2].Replace(". ", "");
|
||||
string authString = $"\tauthor = \"{string.Join(" and ", Author)}\",\n";
|
||||
string edsString = Editor.Length != 0 ?
|
||||
$"\teditor = \"{string.Join(" and ", Editor)}\",\n" : "";
|
||||
|
||||
return $"@{Type}{{{label}_{Year},\n" +
|
||||
authString +
|
||||
edsString +
|
||||
$"\ttitle = {{{Title}}},\n" +
|
||||
$"\tbooktitle = {{{BookTitle}}},\n" +
|
||||
$"\tpublisher = \"{Publisher}\",\n" +
|
||||
$"\tseries = {{{Series}}},\n" +
|
||||
$"\taddress = \"{Address}\",\n" +
|
||||
$"\tyear = \"{Year}\",\n" +
|
||||
$"\tpages = \"{FirstPage}--{LastPage}\",\n" +
|
||||
$"\tpages = \"{Pages}\",\n" +
|
||||
$"\turl = \"{Url}\",\n" +
|
||||
$"\tdoi = \"{Doi}\",\n" +
|
||||
"}\n";
|
||||
@ -218,9 +223,8 @@ namespace Txt2Bib.Records
|
||||
public string BookTitle { get; set; } = "";
|
||||
public ushort Year { get; set; } = 1950;
|
||||
public string Publisher { get; set; } = "";
|
||||
public string Series { get; set; } = "";
|
||||
public string Address { get; set; } = "";
|
||||
public ushort FirstPage { get; set; } = 1;
|
||||
public ushort LastPage { get; set; } = 1;
|
||||
public string Url { get; set; } = "";
|
||||
public string Doi { get; set; } = "";
|
||||
|
||||
@ -229,24 +233,17 @@ namespace Txt2Bib.Records
|
||||
Author = entryLines[1].Split(',').Select(a => Rearrange(a)).ToArray();
|
||||
Year = ushort.Parse(entryLines[2]);
|
||||
Title = entryLines[3];
|
||||
Editor = entryLines[4].Replace("(eds.)", "").Split(',').Select(a => Rearrange(a)).ToArray();
|
||||
Editor = Regex.Replace(entryLines[4], @"\(eds?\.\)", "").Split(',').Select(a => Rearrange(a)).ToArray();
|
||||
BookTitle = entryLines[5];
|
||||
Address = entryLines[6] != String.Empty ? entryLines[6] : Address;
|
||||
Publisher = entryLines[7];
|
||||
try
|
||||
{
|
||||
FirstPage = ushort.Parse(entryLines[8].Split('-')[0]);
|
||||
LastPage = ushort.Parse(entryLines[8].Split('-')[1].TrimEnd('.'));
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
Series = entryLines[6] != String.Empty ? entryLines[6] : Series;
|
||||
Address = entryLines[7] != String.Empty ? entryLines[7] : Address;
|
||||
Publisher = entryLines[8];
|
||||
Pages = CreatePages(entryLines[9]);
|
||||
|
||||
if (entryLines.Length > 9)
|
||||
if (entryLines.Length > 10)
|
||||
{
|
||||
if (IsDoi(entryLines[9])) Doi = entryLines[9];
|
||||
else Url = entryLines[9];
|
||||
if (IsDoi(entryLines[10])) Doi = entryLines[10];
|
||||
else Url = entryLines[10];
|
||||
}
|
||||
|
||||
return ToString();
|
||||
@ -254,7 +251,7 @@ namespace Txt2Bib.Records
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
string label = Author[0][..5].Replace(". ", "");
|
||||
string label = Author[0][..2].Replace(". ", "");
|
||||
string authString = $"\tauthor = \"{string.Join(" and ", Author)}\",\n";
|
||||
string edsString = $"\teditor = \"{string.Join(" and ", Editor)}\",\n";
|
||||
|
||||
@ -264,9 +261,10 @@ namespace Txt2Bib.Records
|
||||
$"\ttitle = {{{Title}}},\n" +
|
||||
$"\tbooktitle = {{{BookTitle}}},\n" +
|
||||
$"\tpublisher = \"{Publisher}\",\n" +
|
||||
$"\tseries = {{{Series}}},\n" +
|
||||
$"\taddress = \"{Address}\",\n" +
|
||||
$"\tyear = \"{Year}\",\n" +
|
||||
$"\tpages = \"{FirstPage}--{LastPage}\",\n" +
|
||||
$"\tpages = \"{Pages}\",\n" +
|
||||
$"\turl = \"{Url}\",\n" +
|
||||
$"\tdoi = \"{Doi}\",\n" +
|
||||
"}\n";
|
||||
|
14
Text2Bib.cs
14
Text2Bib.cs
@ -15,7 +15,7 @@ namespace Txt2Bib
|
||||
/// </summary>
|
||||
public class Text2Bib
|
||||
{
|
||||
private readonly string[] _citTypes = { "J", "B", "C", "P" };
|
||||
private readonly string[] _citTypes = { "J", "B", "C", "P", "PB" };
|
||||
|
||||
/// <summary>
|
||||
/// Generate single .bib file from input text files
|
||||
@ -43,7 +43,8 @@ namespace Txt2Bib
|
||||
{
|
||||
using var reader = File.OpenText(path);
|
||||
byte[] contentBytes = File.ReadAllBytes(path);
|
||||
var content = Encoding.Latin1.GetString(contentBytes);
|
||||
// Assumes UTF8!
|
||||
var content = Encoding.UTF8.GetString(contentBytes);
|
||||
|
||||
IEnumerable<string> entries = new List<string>();
|
||||
try
|
||||
@ -52,7 +53,7 @@ namespace Txt2Bib
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
throw;
|
||||
throw new Exception($"Errore di elaborazione in {entries.Last()}");
|
||||
}
|
||||
|
||||
var bibtex = "";
|
||||
@ -75,7 +76,7 @@ namespace Txt2Bib
|
||||
var lines = entryFromTxt.Trim().Replace("\r", string.Empty).Split("\n");
|
||||
var type = lines.First().Trim();
|
||||
|
||||
if (!IsValidEntry(type)) throw new Exception($"Invalid entry type '{type}'");
|
||||
//if (!IsValidEntry(type)) throw new Exception($"Invalid entry type '{type}'");
|
||||
|
||||
string citation;
|
||||
try
|
||||
@ -84,14 +85,15 @@ namespace Txt2Bib
|
||||
{
|
||||
"J" => new Article().Convert(lines),
|
||||
"B" => new Book().Convert(lines),
|
||||
"PB" => new Book().Convert(lines),
|
||||
"C" => new Chapter().Convert(lines),
|
||||
"P" => new Proceedings().Convert(lines),
|
||||
_ => ""
|
||||
};
|
||||
}
|
||||
catch (Exception)
|
||||
catch (Exception ex)
|
||||
{
|
||||
throw new Exception("Faulty string in " + entryFromTxt);
|
||||
throw new Exception($"Errore in {entryFromTxt}\nMessaggio di errore: \"{ex.Message}\"");
|
||||
}
|
||||
|
||||
return citation;
|
||||
|
@ -5,7 +5,7 @@
|
||||
<TargetFramework>net6.0-windows</TargetFramework>
|
||||
<Nullable>enable</Nullable>
|
||||
<UseWPF>true</UseWPF>
|
||||
<Version>0.1.5</Version>
|
||||
<Version>0.2.0</Version>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
|
Loading…
Reference in New Issue
Block a user