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

sin imagen de perfil
Val: 18
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)
4.448 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
1.022 visualizaciones desde el 13 de Noviembre del 2017
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

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
Program Contador_de_mensajes;
  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];
    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: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
        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
                 Inc(Coincidencias);
 
              If Pos(HoyEs, Cadena[i]) > 0 Then
                 For F:= 1 to 18 Do
                          Begin
                            If Pos(Hora[F],Cadena[i])>0 Then
                            Inc(Horario[F]);
                          End; {If 1}
 
                 If Pos(MananaEs, Cadena[i]) > 0 Then
                 For F:= 19 to 25 Do
                          Begin
                            If Pos(Hora[F],Cadena[i])>0 Then
                            Inc(Horario[F]);
                          End; {If 2}
 
               End;
          End;  {For i}
 
 
{            Writeln(Usuario[N],'------',Coincidencias);}
 
                 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>');
            Horarios:='';
            Coincidencias:=0;
            For f:= 1 to 25 Do
              Horario[f]:=0;
      End;{For N}
    End;
 
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);
                NumMaxCadena:=NumCadena;
                SaltodeLinea:=False;
                CapturarTexto:=True;
              End;
 
    {Encontrar "salto de linea"}
        If Ch=#10 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]:='';
           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]:=', 06:';
    Hora[2]:=', 07:';
    Hora[3]:=', 08:';
    Hora[4]:=', 09:';
    Hora[5]:=', 10:';
    Hora[6]:=', 11:';
    Hora[7]:=', 12:';
    Hora[8]:=', 13:';
    Hora[9]:=', 14:';
    Hora[10]:=', 15:';
    Hora[11]:=', 16:';
    Hora[12]:=', 17:';
    Hora[13]:=', 18:';
    Hora[14]:=', 19:';
    Hora[15]:=', 20:';
    Hora[16]:=', 21:';
    Hora[17]:=', 22:';
    Hora[18]:=', 23:';
    Hora[19]:=', 00:';
    Hora[20]:=', 01:';
    Hora[21]:=', 02:';
    Hora[22]:=', 03:';
    Hora[23]:=', 04:';
    Hora[24]:=', 05:';
    Hora[25]:=', 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;
 
 
  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('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);
      End;
 
    Str(m,Mes);
    HoyEs  :=Concat(Mes, '/', Dia, '/');
    MananaEs:=Concat(Mes, '/', Manana, '/');
    Writeln;
    Writeln('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,'.HTML');
      End;
 
{
    If y <> 2017 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
    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>00:06</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>');
    End;
 
    Close(Result);
  end.



Comentarios sobre la versión: 1.13 (0)


No hay comentarios
 

Comentar la versión: 1.13

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

1.2

Publicado el 4 de Junio del 2018gráfica de visualizaciones de la versión: 1.2
3.427 visualizaciones desde el 4 de Junio del 2018
http://lwp-l.com/s4302