ฉันได้เขียนTinyCsvParserสำหรับ. NET ซึ่งเป็นหนึ่งในตัวแยกวิเคราะห์. NET ที่เร็วที่สุดและตั้งค่าได้อย่างสูงในการแยกวิเคราะห์เกือบทุกรูปแบบ CSV
เผยแพร่ภายใต้ลิขสิทธิ์ของ MIT:
คุณสามารถใช้NuGetเพื่อติดตั้ง เรียกใช้คำสั่งต่อไปนี้ในคอนโซลการจัดการแพคเกจ
PM> Install-Package TinyCsvParser
การใช้
ลองนึกภาพเรามีรายชื่อบุคคลในไฟล์ CSV ที่persons.csv
มีชื่อนามสกุลและวันเกิด
FirstName;LastName;BirthDate
Philipp;Wagner;1986/05/12
Max;Musterman;2014/01/02
รูปแบบโดเมนที่สอดคล้องกันในระบบของเราอาจมีลักษณะเช่นนี้
private class Person
{
public string FirstName { get; set; }
public string LastName { get; set; }
public DateTime BirthDate { get; set; }
}
เมื่อใช้ TinyCsvParser คุณจะต้องกำหนดการแมประหว่างคอลัมน์ในข้อมูล CSV และคุณสมบัติในรูปแบบโดเมนของคุณ
private class CsvPersonMapping : CsvMapping<Person>
{
public CsvPersonMapping()
: base()
{
MapProperty(0, x => x.FirstName);
MapProperty(1, x => x.LastName);
MapProperty(2, x => x.BirthDate);
}
}
และจากนั้นเราสามารถใช้การทำแผนที่การแยกข้อมูล CSV CsvParser
ด้วย
namespace TinyCsvParser.Test
{
[TestFixture]
public class TinyCsvParserTest
{
[Test]
public void TinyCsvTest()
{
CsvParserOptions csvParserOptions = new CsvParserOptions(true, new[] { ';' });
CsvPersonMapping csvMapper = new CsvPersonMapping();
CsvParser<Person> csvParser = new CsvParser<Person>(csvParserOptions, csvMapper);
var result = csvParser
.ReadFromFile(@"persons.csv", Encoding.ASCII)
.ToList();
Assert.AreEqual(2, result.Count);
Assert.IsTrue(result.All(x => x.IsValid));
Assert.AreEqual("Philipp", result[0].Result.FirstName);
Assert.AreEqual("Wagner", result[0].Result.LastName);
Assert.AreEqual(1986, result[0].Result.BirthDate.Year);
Assert.AreEqual(5, result[0].Result.BirthDate.Month);
Assert.AreEqual(12, result[0].Result.BirthDate.Day);
Assert.AreEqual("Max", result[1].Result.FirstName);
Assert.AreEqual("Mustermann", result[1].Result.LastName);
Assert.AreEqual(2014, result[1].Result.BirthDate.Year);
Assert.AreEqual(1, result[1].Result.BirthDate.Month);
Assert.AreEqual(1, result[1].Result.BirthDate.Day);
}
}
}
คู่มือผู้ใช้
คู่มือผู้ใช้ฉบับสมบูรณ์มีอยู่ที่: