Código de Pascal/Turbo Pascal - Contador de mensajes de Whatsapp

sin imagen de perfil
Val: 16
Ha disminuido 1 puesto en Pascal/Turbo Pascal (en relación al último mes)
Gráfica de Pascal/Turbo Pascal

Contador de mensajes de Whatsappgráfica de visualizaciones


Pascal/Turbo Pascal

Actualizado el 4 de Junio del 2018 por Alejandro (Publicado el 13 de Noviembre del 2017)
2.376 visualizaciones desde el 13 de Noviembre del 2017
Este programa esta creado para administradores de Whatsapp…

Objetivo
Mostrar por horarios, correspondientes al día especificado, la cantidad de veces que los usuarios de Whatsapp han participado (enviado mensajes), datos representados en una tabla con formato “.htm”.

Funcionamiento
El Programa lee un archivo de texto creado por la aplicación "Whatsapp", cuando el usuario usa la acción "Enviar chat por correo". Ese archivo resultante al día de hoy (2017) está en formato de texto, es asignado un nombre de archivo que inicia con "Chat de Whatsapp con....txt" y se guarda en la carpeta ".Shared" del dispositivo, o bien en el correo electrónico seleccionado.

Nota
Gracias a los emuladores de MS-DOS, funciona en un dispositivo con Sistema Android, de tal manera que la forma correcta de ejecutarlo; es alojando el programa y “montar la unidad C:\” en la carpeta “.Shared” de “Whatsapp”.

Imagen1

Imagen5

Requerimientos

Sistema operativo que soporte MS-DOS o su emulación
Compilador Turbo Pascal 5.5 o superior
Visor de archivos en formato ".html"
Contar con el archivo resultante ("Enviar chat por correo") creado por la aplicación "Whatsapp"

1.13

Actualizado el 27 de Noviembre del 2017 (Publicado el 13 de Noviembre del 2017)gráfica de visualizaciones de la versión: 1.13
708 visualizaciones desde el 13 de Noviembre del 2017

1.2

Publicado el 4 de Junio del 2018gráfica de visualizaciones de la versión: 1.2
1.669 visualizaciones desde el 4 de Junio del 2018
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

El registro de chats que genera la App WhatsApp, fue modificado retirando una "coma" entre la hora y la fecha, motivo por el cual fue modificado el Procedimiento "Fijar Horarios".
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
uses Dos,Crt;
  var
    DirInfo: SearchRec;
    FileName:Array [1..20] of String[20];
    Cadena:Array [0..1150] of String [47];
    Usuario:Array [0..255] Of String [17];
    ConteoTotal:Integer;
    Hora:Array [0..25] Of String [5];
    Horario:Array [1..25] Of Integer;
    Horarios,
    NombreResultado,
    TxtMin,TxtH:String;
    HoraAux:String[3];
    NumFileName,
    NumCadena,
    LugarA,
    LugarB,
    ContadorUsuario,
    Coincidencias,NumUsuario:Integer;
    i,N,S,f,
    MaxNumControl01,
    NumMaxCadena,
    ErrorNum:Integer;
    SaltodeLinea,
    CapturarTexto,
    CadenaCorrecta,
    UsuarioIngresado,
    IncluirCadena:Boolean;
    NombreArchivo,
    Result:Text;
    AuxUsuario:String[17];
    {Fecha}
    y, m, d, dow : Word;
    Dia,
    Mes,
    Manana,
    HoyEs,
    MananaEs,
    CreaNombre:String;
    {Horarios}
    h, min, seg, hund, NDia : Word;
 
 
    Procedure SepararUsuarios;
 
    Begin
    {Se crea un listado con los Usuarios, recorriendo las variables y encontrando
    las repetidas}
 
 
    ContadorUsuario:=1;
 
    For i:= 1 to NumMaxCadena Do
      Begin
        Usuario[Contadorusuario]:='';
        LugarA:=Pos(' - ',Cadena[i]);
        LugarB:=Pos(': ',Cadena[i]);
        AuxUsuario:=Copy(Cadena[i], LugarA+3, LugarB-LugarA-3);
        UsuarioIngresado:=False;
        {Writeln(AuxUsuario);}
        {Verifica que el nuevo uauario no esta en la lista}
        For N:= 1 to ContadorUsuario Do
            If Usuario[N]=AuxUsuario Then
               UsuarioIngresado:=True;
 
        {Si el usuario no esta entonces se toma un valor}
 
        If Not UsuarioIngresado Then
           Begin
             Usuario[ContadorUsuario]:=AuxUsuario;
             Inc(ContadorUsuario);
           End;
 
 
      End;{For}
      Dec(ContadorUsuario);
   End;
 
    Procedure ContarCoincidencias;
    Begin
      {Ya teniendo los usuarios (255 como maximo) se inicia el conteo
      las veces que se repite la coincidencia en todas las cadenas de texto}
 
      Coincidencias:=0;
      NumUsuario:=0;
 
      For f:= 1 to 25 Do
          Horario[f]:=0;
      Horarios:='';
 
    For N:= 1 To ContadorUsuario Do {Checa usuario por usuario (max 255)}
      Begin
        IncluirCadena:=False;
        For i:= 1 to NumMaxCadena Do {Recorre todo el contenido (max 1000)}
          Begin
            {Writeln(Cadena[i]);}
            {LugarHora:=
 
            AQUI VA A BUSCAR LA COINCIDENCIA DE LOS HORARIOS
            DEPENDIENDO DEL HORARIO SE DEBEN INGRESAR TABULACIONES}
 
            LugarA:=Pos(' - ',Cadena[i]);
            LugarB:=Pos(': ',Cadena[i]);
            AuxUsuario:=Copy(Cadena[i], LugarA+3, LugarB-LugarA-3);
 
            If Usuario[N]=AuxUsuario Then
               Begin
                 If Pos(HoyEs, Cadena[i]) > 0 Then
                    Begin
                      For F:= 1 to 18 Do
                          If Pos(Hora[F],Cadena[i])>0 Then
                             Begin
                               Inc(Horario[F]);
                               Inc(Coincidencias);
                               IncluirCadena:=True;
                             End;
                    End; {If HoyEs}
 
                 If Pos(MananaEs, Cadena[i]) > 0 Then
                    Begin
                      For F:= 19 to 25 Do
                          If Pos(Hora[F],Cadena[i])>0 Then
                             Begin
                               Inc(Horario[F]);
                               Inc(Coincidencias);
                               IncluirCadena:=True;
                             End;
                    End;{If MananaEs}
 
               End;{If Usuario [N]}
          End;  {For i}
 
          ConteoTotal:=ConteoTotal+Coincidencias;
          {   Writeln(Usuario[N],'------',Coincidencias);}
          If IncluirCadena Then  {Se evita escriba registros vacios}
             Begin
               For F:= 1 to 25 Do
                   Begin
                     Str(Horario[F],HoraAux);
                     If Horario[F] = 0 Then
                        HoraAux:='';
                        Horarios:=Horarios+'<td>'+HoraAux+'</td>';
                     End;
 
               Inc(NumUsuario);
               Writeln(Result,'<tr><td>',NumUsuario,'</td>',
                              '<td>',Usuario[N],'</td>',
                              '<td>',Coincidencias,'</td>',
                              Horarios,'</tr>');
             End; {If IncluirCadena}
              Horarios:='';
              Coincidencias:=0;
              For f:= 1 to 25 Do
                  Horario[f]:=0;
      End;{For N}
    End;{Procedure}
 
Procedure LeerArchivo(Nombre:String);
  var
    f : text;
    ch: char;
  Begin
    SaltodeLinea:=False;
    CadenaCorrecta:=False;
    NumMaxcadena:=0;
    {Leer archivo}
    Assign(F, Nombre);
    Reset(F);
    While not Eof(f) do
      Begin
        Read(F,Ch);
 
    {Saber si el caracter ANTERIOR coincide con un "salto de linea",
    si es asi verificar que el siguiente caracter sea un numero
    para dar pauta a que probablemente se trata de la hora y fecha}
 
        If SaltodeLinea Then
           If Ord(Ch) in [48..57] Then
              Begin
                Inc(NumCadena);
                {ESTE CONTROL EVITA UN DESBORDAMIENTO DE VARIABLES}
                If NumCadena>1148 Then
                   Begin
                     Dec(NumCadena);
                     Writeln('ALERTA: Se ha sobrepasado el maximo de variables');
                   End;
                NumMaxCadena:=NumCadena;
                SaltodeLinea:=False;
                CapturarTexto:=True;
              End;
 
    {Encontrar "salto de linea"}
        If Ord(Ch) in [10,13] Then
             SaltodeLinea:=True;
 
    {Si se detecto que el segundo caracter es numero
    se almacena en una variable cadena tipo arreglo}
 
      If CapturarTexto And
         Not (Ord(Ch) In [Ord(226),Ord(128),Ord(170),Ord(43),Ord(172)]) Then
             Begin
               Cadena[NumCadena]:=Cadena[NumCadena]+Ch;
             End;
 
    {Ahora tambien se verifica que contenga un separador de fecha en el segundo o tercer caracter
    por ejemplo 2/12/2017 o 12/12/2017, de lo contrario se continua con la misma variable}
 
    If Length(Cadena[NumCadena]) = 6 Then
    If ((Pos(HoyEs, Cadena[NumCadena]) > 0) Or
       (Pos(MananaEs, Cadena[NumCadena]) > 0)) Then
       CadenaCorrecta:=True
       Else
         Begin
           CadenaCorrecta:=False;
           CapturarTexto:=False;
           Cadena[NumCadena]:='';
           {ESTE CONTROL EVITA UN ERROR ALEATORIO "-1", FALTA DEPURAR}
           If NumCadena>0 Then
           Dec(NumCadena);
           {Writeln(Cadena[NumCadena],'--------',numcadena);}
         End;
 
    {Si se considera que las pruebas han sido superadas se continua almacenando
     en una variable}
 
{    If CadenaCorrecta Then
       Writeln(Cadena[NumCadena],'--------',numcadena);}
 
    end;
  Close(F);
  End;{Procedure}
 
  Procedure FijarHorarios;
  Begin
    Hora[1] :='8 06:';
    Hora[2] :='8 07:';
    Hora[3] :='8 08:';
    Hora[4] :='8 09:';
    Hora[5] :='8 10:';
    Hora[6] :='8 11:';
    Hora[7] :='8 12:';
    Hora[8] :='8 13:';
    Hora[9] :='8 14:';
    Hora[10]:='8 15:';
    Hora[11]:='8 16:';
    Hora[12]:='8 17:';
    Hora[13]:='8 18:';
    Hora[14]:='8 19:';
    Hora[15]:='8 20:';
    Hora[16]:='8 21:';
    Hora[17]:='8 22:';
    Hora[18]:='8 23:';
    Hora[19]:='8 00:';
    Hora[20]:='8 01:';
    Hora[21]:='8 02:';
    Hora[22]:='8 03:';
    Hora[23]:='8 04:';
    Hora[24]:='8 05:';
    Hora[25]:='8 06:';
 
  End;
 Function CrearNombre:String;
       Begin
 
         If Length (Mes)= 1 Then Mes:='0' + Mes;
         If Length (Dia)= 1 Then Dia:='0' + Dia;
         Str(H,TxtH);
         Str(Min,TxtMin);
         If Length (TxtH)= 1 Then TxtH:='0' + TxtH;
         If Length (TxtMin)= 1 Then TxtMin:='0' + TxtMin;
 
         CreaNombre:=Concat(Mes,Dia,TxtH,TxtMin,'.HTML');
       End;
 
 
  function IntToStr(i: Longint): string;
  { Convert any Integer type to a string }
  var
    s: string[11];
  begin
    Str(i, s);
    IntToStr := s;
  end;
 
 
 
  Begin
    ClrScr;
    GetDate(y,m,d,dow);
    GetTime(h,min,seg,hund);
 
    {WriteLn(h,':',min);}
    {WriteLn('Today is ',m:0, '/', d:0, '/', y);}
    Writeln('Contador de eventos para Chats de Whatsapp');
    Writeln('Correo tusdatosaqui@gmail.com');
    Writeln;
    Writeln('Escribe el numero del dia a procesar y oprime ENVIAR default( HOY ES ',d,')');
    Readln(Dia);
    If Dia<>'' Then
       Begin
         Val(Dia,NDia,ErrorNum);
         { Error during conversion to Integer? }
         if ErrorNum <> 0 then
            WriteLn('Escriba un numero del 1 al 31')
            Else
              Begin
                Str(NDia,Dia);
                Str(NDia+1,Manana);
              End;
       End
    Else
      Begin
        Str(d,Dia);
        Str(d+1,Manana);
        WriteLn('...Dia: ',Dia);
        WriteLn;
      End;
 
    Str(m,Mes);
    HoyEs  :=Concat(Mes, '/', Dia, '/');
    MananaEs:=Concat(Mes, '/', Manana, '/');
    Write;
    Write('Escribe el nombre del archivo resultante y oprime ENVIAR (default "MES+DIA.Htm")');
    NombreResultado:='';
    Readln(NombreResultado);
    If NombreResultado='' Then
       Begin
         If Length (Mes)= 1 Then Mes:='0' + Mes;
         If Length (Dia)= 1 Then Dia:='0' + Dia;
         Str(H,TxtH);
         Str(Min,TxtMin);
         If Length (TxtH)= 1 Then TxtH:='0' + TxtH;
         If Length (TxtMin)= 1 Then TxtMin:='0' + TxtMin;
 
         NombreResultado:=Concat(Mes,Dia,TxtH,TxtMin,'.HTM');
         Write('...Nombre del archivo: ',NombreResultado);
         WriteLn;
       End
    Else
      NombreResultado:=NombreResultado+'.htm';
 
    WriteLn;
    WriteLn('--------------------------------------------------------------');
    If y <> 2018 Then
       Begin
         Writeln('Actualice el Programa... Whatsapp 5215541491959 o tusdatosaqui@gmail.com');
         halt(0);
       End;
 
    FijarHorarios;
    NumFileName:=0;
    FindFirst('*.txt', Archive, DirInfo);
    while DosError = 0 do
    begin
 
      {WriteLn(DirInfo.Name);}
      Inc(NumFileName);
      Filename[NumFileName]:=DirInfo.Name;
      FindNext(DirInfo);
    end;
    MaxNumControl01:=NumFileName;
 
 
    Assign(Result,NombreResultado);
    Rewrite(Result);
    Append(Result);
 
    For S:= 1 to MaxNumControl01 Do
    Begin
    ConteoTotal:=0; {Procedure ContarCoincidencias}
    Writeln('Trabajando en Archivo: ',FileName[S]);
    Writeln('fecha: ',HoyEs,'2017');
    Writeln('horario de corte: ',h,':',min,' horas');
    Writeln;
 
    Writeln(Result,'<Br>');
    Writeln(Result,'<Br>');
    Writeln(Result,'<Br>');
    Writeln(Result,'<Br>');
    Writeln(Result,'Conteo de reportes de Grupo "',FileName[S],'"<Br>');
    Writeln(Result,'Fecha: ',HoyEs,'2017 <Br>');
    Writeln(Result,'Cierre del conteo: ',h,':',min,' horas  <Br>');
    Writeln(Result,'<Table Border="1" CellPadding="0" CellSpacing="0" Width="35%">');
    Writeln(Result,'<tr><td>-#-</td><td>xxxxxxxxxxUsuarioxxxxxxxxxx</td><td>Registros</td><td>06:00</td>',
                   '<td>07:00</td><td>08:00</td>',
                   '<td>09:00</td><td>10:00</td><td>11:00</td><td>12:00</td><td>13:00</td>',
                   '<td>14:00</td><td>15:00</td><td>16:00</td><td>17:00</td><td>18:00</td>',
                   '<td>19:00</td><td>20:00</td><td>21:00</td><td>22:00</td><td>23:00</td>',
                   '<td>00:00</td><td>01:00</td><td>02:00</td><td>03:00</td><td>04:00</td>',
                   '<td>05:00</td><td>06:00</td></tr>');
 
 
    For i:= 0 to 1000 Do
        Cadena[i]:='';
      NumCadena:=0;
      LeerArchivo(FileName[S]);
      SepararUsuarios;
      ContarCoincidencias;
      Writeln(Result,'</Table><Br><H2>Registros:',IntToStr(ConteoTotal),'</H2>');
    End;
 
    Close(Result);
    ConteoTotal:=0;{Procedure ContarCoincidencias}
  end.



Comentarios sobre la versión: 1.2 (0)


No hay comentarios
 

Comentar la versión: 1.2

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s4302