Files
ECO2-OD/GetReport/Program.cs
2018-12-09 20:18:51 +09:00

127 lines
5.0 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace GetReport
{
/// <summary>
/// Ecl2파일에서 최종보고서를 불러옵니다.
/// </summary>
class Program
{
struct s_Porject
{
public string Filename;
public string Maketime;
public string Desc;
public string UIVersion;
public string LGVersion;
public string Name;
public string SFType;
public string MakeTime;
public string EditTime;
}
static void Main(string[] args)
{
//#if(DEBUG)
// Console.WriteLine("Debug Mode");
// Console.WriteLine(string.Format("Param len={0}", args.Length));
//#endif
string msgtitle =
"이 프로그램은 ECO2-OD의 저장파일(*.ecl2)에서 최종결과 보고서를 추출하는 프로그램입니다.\r\n" +
"프로그램 실행시 파라미터로 추출하고자하는 파일명을 입력하세요\r\n\r\n" +
"경로 및 파일명에 공백이 있는 경우에는 큰따옴표로 묶어서 입력하시기 바랍니다.\r\n\r\n" +
"예) GetReport.exe " + (char)(0x22) + "c:\\Sample File\\test.ecl2" + (char)(0x22) +
"\r\n예) GetReport.exe new.ecl2";
if (args.Length < 1)
{
//display Usage
System.Text.StringBuilder sb = new StringBuilder();
sb.AppendLine(msgtitle);
sb.AppendLine();
//sb.AppendLine("아무키나 누르면 종료합니다");
Console.WriteLine(sb.ToString());
//Console.ReadKey();
return;
}
System.IO.FileInfo fi = new System.IO.FileInfo(args[0]);
if (!fi.Exists)
{
System.Text.StringBuilder sb = new StringBuilder();
sb.AppendLine(msgtitle);
sb.AppendLine();
sb.AppendLine("존재하지 않는 파일명을 입력했습니다");
sb.AppendLine("파일명 : " + fi.FullName);
Console.WriteLine(sb.ToString());
//Console.ReadKey();
return;
}
//자료를 읽어서 테이블을 추출한 후 그 정보를 역 출력한다
byte[] source = System.IO.File.ReadAllBytes(fi.FullName);
if (source.Length < 4)
{
System.Text.StringBuilder sb = new StringBuilder();
sb.AppendLine(msgtitle);
sb.AppendLine();
sb.AppendLine("데이터가 올바르지 않습니다.");
sb.AppendLine("데이터길이 : " + source.Length.ToString());
Console.WriteLine(sb.ToString());
//Console.ReadKey();
return;
}
System.IO.MemoryStream fs = new System.IO.MemoryStream(source);
System.IO.BinaryReader Br = new System.IO.BinaryReader(fs, System.Text.Encoding.Default);
s_Porject prj = new s_Porject();
//read data
prj.Filename = fi.FullName;
prj.SFType = System.Text.Encoding.Default.GetString(Br.ReadBytes(2));
prj.UIVersion = System.Text.Encoding.Default.GetString(Br.ReadBytes(10));
prj.LGVersion = System.Text.Encoding.Default.GetString(Br.ReadBytes(10));
prj.Name = System.Text.Encoding.Default.GetString(Br.ReadBytes(100));
prj.Desc = System.Text.Encoding.Default.GetString(Br.ReadBytes(256));
prj.MakeTime = System.Text.Encoding.Default.GetString(Br.ReadBytes(19));
prj.EditTime = System.Text.Encoding.Default.GetString(Br.ReadBytes(19));
//setting data read
System.Data.DataSet DSET1 = new System.Data.DataSet();
Int64 DS1Len = Br.ReadInt64();
byte[] DS1 = Br.ReadBytes((int)DS1Len);
System.IO.MemoryStream Ms = new System.IO.MemoryStream(DS1);
DSET1.ReadXml(Ms);
DSET1.AcceptChanges();
Ms.Close();
//readreport
System.Data.DataSet DSETR1 = new System.Data.DataSet();
DS1Len = Br.ReadInt64();
DS1 = Br.ReadBytes((int)DS1Len);
Ms = new System.IO.MemoryStream(DS1);
DSETR1.ReadXml(Ms);
DSETR1.AcceptChanges();
Ms.Close();
//System.Text.StringBuilder sb2 = new StringBuilder();
//sb2.AppendLine("Table Count = " + DSETR1.Tables.Count.ToString());
//sb2.AppendLine("Table 1 = " + DSETR1.Tables[0].ToString());
//보고서테이블의 내용을 화면에 출력한다.
System.IO.StringWriter sw = new System.IO.StringWriter();
DSETR1.Tables[0].WriteXml(sw, false);
Console.WriteLine(sw.ToString());
//sb2.AppendLine(sw.ToString());
sw.Dispose();
//Console.ReadKey();
}
}
}