public void GenerarXMLIntracom(string _NombreFichero) { Intracom funcion = new Intracom(); string _NomFicheroWrk = _NombreFichero; try { ITInvoicesBatch _LoteOperIntracom = new ITInvoicesBatch(); ITInvoice _OperIntracomAct = new ITInvoice(); Party _Titular = new Party(); using (StreamReader _Lector = new StreamReader(_NomFicheroWrk)) { while (_Lector.Peek() > -1) { string _RegFichero = _Lector.ReadLine(); if (!String.IsNullOrEmpty(_RegFichero)) { // Con creamos un Array con los distintos campos que contiene el registro separados por ";" string[] _CamposReg = _RegFichero.Split(';'); string _TipoReg = _CamposReg[0]; switch (_TipoReg) { case "CABE": _Titular = funcion.TratarRegCabecera(_CamposReg); _LoteOperIntracom.Titular = _Titular; string _TipoComunicacion = _CamposReg[3]; switch (_TipoComunicacion) { case "A0": _LoteOperIntracom.CommunicationType = CommunicationType.A0; break; case "A1": _LoteOperIntracom.CommunicationType = CommunicationType.A1; break; case "A4": _LoteOperIntracom.CommunicationType = CommunicationType.A4; break; } break; case "FACT": _OperIntracomAct = new ITInvoice(); _OperIntracomAct = funcion.TratarOperIntracom(_CamposReg, _Titular); _LoteOperIntracom.ITInvoices.Add(_OperIntracomAct); break; case "FINI": // Procedemos a generar el XML final. DateTime _FechaActual = DateTime.Today; //Obtenemos la fecha actual sin la hora string nombrefichero = "SII_Intracom_" + _Titular.TaxIdentificationNumber + "_" + _FechaActual.ToString("yyyyMMdd") + ".XML"; string XmlResult = "C:/Temp/" + nombrefichero; _LoteOperIntracom.GetXml(XmlResult); string _msg = "Fichero XML generado: " + XmlResult; MessageBox.Show(_msg, "Información", MessageBoxButtons.OK, MessageBoxIcon.Information); break; default: string _msgAviso = "Tipo Registro incorrecto: " + _TipoReg; MessageBox.Show(_msgAviso, "Aviso", MessageBoxButtons.OK, MessageBoxIcon.Warning); break; } } } } } catch (Exception ex) { string _msgError = "Error: " + ex.Message; MessageBox.Show(_msgError, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } }
public void GeneraFicheros(string _NomFichero) { if (File.Exists(_NomFichero)) { string _TrabajarCon = "CORE"; //string _TrabajarCon = "BUSI"; // Leeremos la primera línea del fichero, en la que hay un campo que indica el tipo // de facturas que contiene. Posteriormente, llamaremos a la función correspondiente // para generar el XML correcto. StreamReader _Lector = new StreamReader(_NomFichero); string _Cabecera = _Lector.ReadLine(); _Lector.Close(); string[] _CamposReg = _Cabecera.Split(';'); string _TipoFichero = _CamposReg[4]; switch (_TipoFichero) { case "EMI": { if (_TrabajarCon == "CORE") { EmitidasEnvel FuncionesEmiEnvel = new EmitidasEnvel(); FuncionesEmiEnvel.GenerarXMLEmitidasEnvel(_NomFichero); } else { Emitidas FuncionesEmi = new Emitidas(); FuncionesEmi.GenerarXMLEmitidas(_NomFichero); } break; } case "REC": { if (_TrabajarCon == "CORE") { RecibidasEnvel FuncionesRecEnvel = new RecibidasEnvel(); FuncionesRecEnvel.GenerarXMLRecibidasEnvel(_NomFichero); } else { Recibidas FuncionesRec = new Recibidas(); FuncionesRec.GenerarXMLRecibidas(_NomFichero); } break; } case "INT": { if (_TrabajarCon == "CORE") { IntracomEnvel FuncionesIntEnvel = new IntracomEnvel(); FuncionesIntEnvel.GenerarXMLIntracomEnvel(_NomFichero); } else { Intracom FuncionesInt = new Intracom(); FuncionesInt.GenerarXMLIntracom(_NomFichero); } break; } default: { string _msg = "Este fichero no se puede tratar en este programa"; MessageBox.Show(_msg, "AVISO", MessageBoxButtons.OK, MessageBoxIcon.Warning); break; } } } else { string _msg = "El fichero indicado no existe"; MessageBox.Show(_msg, "ERROR", MessageBoxButtons.OK, MessageBoxIcon.Error); } }