O FileParser é uma biblioteca .NET projetada para ler arquivos de texto linha a linha, salvando o conteúdo de cada linha nos tipos básicos VARs (int, dupla, string, etc.).
Nullable é ativado a partir de 1.6.x. Este projeto nasceu com um objetivo muito específico: fornecendo uma ferramenta com quem analise os arquivos facilmente com uma estrutura conhecida, idealmente sendo tão flexível e fácil de usar quanto a abordagem padrão de IO C ++.
Para quem não entende o que quero dizer, aqui está um caso de uso simples (também repositada):
Dado o seguinte input.txt , que contém um número inteiro n (> = 0) seguido de n duplas e uma string final,
5 1.1 3.14159265 2.2265 5.5 10 fish Um snippet .cpp simples como o seguinte pode processar input.txt , desde que o arquivo seja selecionado como fonte de entrada padrão:
./myExecutable < input.txt > output.txt
# include < iostream >
# include < list >
# include < string >
int main ()
{
int _integer;
std::string _str;
std::list< double > _list;
double _auxdouble;
// Input start;
std::cin>>_integer;
for ( int i= 0 ; i<_integer; ++i)
{
std::cin>>_auxdouble;
_list. push_back (_auxdouble);
}
std::cin>>_str;
// Input end
// Data processing
// Output start
std::cout<<_integer<< " " ;
for ( const double & d : _list)
std::cout<<d<< " " ;
std::cout<<_str;
// Output end
return 0 ;
} Parece fácil processar esse tipo de arquivo .txt simples usando C ++, certo?
Bem, o uso de C# não é tão direto, e é por isso que FileParser foi criado para:
using System ;
using System . Collections . Generic ;
using System . Globalization ;
using System . IO ;
using FileParser ;
namespace FileParserSample
{
class Program
{
static void Main ( string [ ] args )
{
var cultureInfo = new CultureInfo ( "en-US" ) ;
CultureInfo . DefaultThreadCurrentCulture = cultureInfo ;
List < double > listDouble = new List < double > ( ) ;
string str ;
// Input start
IParsedFile file = new ParsedFile ( "SimpleInput.txt" ) ;
IParsedLine firstLine = file . NextLine ( ) ;
int _integer = firstLine . NextElement < int > ( ) ;
for ( int i = 0 ; i < _integer ; ++ i )
listDouble . Add ( firstLine . NextElement < double > ( ) ) ;
str = firstLine . NextElement < string > ( ) ;
// Input end
// Data Processing
// Output start
StreamWriter writer = new StreamWriter ( ".. \ CSharpSimpleOutput.txt" ) ;
using ( writer )
{
writer . WriteLine ( _integer + " " + string . Join ( null , listDouble ) ) ;
}
// Output end
}
}
} Fiz o meu melhor para criar um wiki descrevendo a API FileParser.
Além do wiki, alguns projetos reais (próprios) onde foi usado são:
Se alguém mais usar o FileParser, ficarei feliz em aceitar sugestões e resolver qualquer dúvida.
Basta abrir um problema :)