IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MATLAB Discussion :

transférer un fichier log vers une base de données


Sujet :

MATLAB

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 36
    Points : 35
    Points
    35
    Par défaut transférer un fichier log vers une base de données
    bonjour ,
    je vous serais très reconnaissante de répondre à ma question

    J'ai un petit problème, c'est que j'ai un fichier log qui contient plusieurs lignes.

    Voici un petit exemple de mon fichier :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    123.123.123.123 - - [26/Apr/2000:00:23:48 -0400] "GET /pics/wpaper.gif HTTP/1.0" 200 6248 "http://www.jafsoft.com/asctortf/" "Mozilla/4.05 (Macintosh; I; PPC)"
    123.123.123.123 - - [26/Apr/2000:00:23:47 -0400] "GET /asctortf/ HTTP/1.0" 200 8130 "http://search.netscape.com/Computers/Data_Formats/Document/Text/RTF" "Mozilla/4.05 (Macintosh; I; PPC)"
    123.123.123.123 - - [26/Apr/2000:00:23:48 -0400] "GET /pics/5star2000.gif HTTP/1.0" 200 4005 "http://www.jafsoft.com/asctortf/" "Mozilla/4.05 (Macintosh; I; PPC)"
    123.123.123.123 - - [26/Apr/2000:00:23:50 -0400] "GET /pics/5star.gif HTTP/1.0" 200 1031 "http://www.jafsoft.com/asctortf/" "Mozilla/4.05 (Macintosh; I; PPC)"
    123.123.123.123 - - [26/Apr/2000:00:23:51 -0400] "GET /pics/a2hlogo.jpg HTTP/1.0" 200 4282 "http://www.jafsoft.com/asctortf/" "Mozilla/4.05 (Macintosh; I; PPC)"
    123.123.123.123 - - [26/Apr/2000:00:23:51 -0400] "GET /cgi-bin/newcount?jafsof3&width=4&font=digital&noshow HTTP/1.0" 200 36 "http://www.jafsoft.com/asctortf/" "Mozilla/4.05 (Macintosh; I; PPC)"

    J'aimerais bien découper ce fichier en @ip + Username+
    Access request + Result status code+ Bytes transferred+ Referrer URL + User Agent

    Username: "- -"
    Access request : "GET /download/windows/asctab31.zip HTTP/1.0"
    Result status code : "200"
    Bytes transferred : "1540096"
    Referrer URL : "http://www.htmlgoodies.com/downloads/freeware/webdevelopment/15.html"

    User Agent : "Mozilla/4.7 [en]C-SYMPA (Win95; U)"



    C'était le découpage de chaque ligne et je veux transférer ces donnés dans une base de données, c-a-d, chaque valeur dans une table, par exemple la variable IP je veux la mettre dans une table nommée @ip,etc...


    Et de mon avis , je me suis proposée de créer une table supplémentaire nommée session pour faire le lien entre ces tables.

    J'ai un peu commencé le travail, mais je me suis bloquée,

    svp aidez moi, je ne sais plus quoi faire.
    merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 53 166
    Points
    53 166
    Par défaut
    Je ne suis pas sûr que MATLAB soit l'outil le plus approprié pour faire ce que tu cherches à faire

    Mais bon, si tu insistes, tu dois décomposer ton problème en 2 parties :

    1. extraction des informations contenues dans le fichier log
    2. transfert vers une base de données


    Commençons par le début, as-tu réussi à lire le fichier log ?
    Tu devrais pouvoir t'en sortir en utilisant les fonctions TEXTREAD ou TEXTSCAN
    Fais une petite recherche sur ce forum, il y a de nombreux exemples.
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 36
    Points : 35
    Points
    35
    Par défaut suivi du travail
    bonjour,
    merci infiniment d'accepter de m'aider, c'est très gentil,
    en ce qui concerne le découpage (CAD la première partie du problème comme vous venez de dire), j'ai essayé de faire ce découpage en utilisant la fonction " strtok ", j'ai mis le résultat du découpage dans 1 tableau (a), bref voici le code de la boucle

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     j=1;v_del=[' ','[',':','"',' ',' ',' ','"','?',' '];
     fid=fopen('log.txt','r+');
     while ~feof(fid)
     line = fgetl(fid);disp(line);
     for i=1:10
     [x,y]=strtok(line,v_del(i));
     line=y;
     a{j,i}=x;
     end
     j=j+1;
     end
     disp(a)
    et ça m'a donné comme résultat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     161.31.132.116 - - [21\dec\2001:08:42:55-0500] "GET/home.htm TTP/1.0" 200 4392 "http://fr.search.yahoo.com/fr?p=peinture" "mozilla/4.7 [en] (win98)"
     161.31.132.117 - - [21\dec\2001:08:42:55-0500] "GET/home.htm HTTP/1.0" 200 4392 "http://fr.search.yahoo.com/fr?p=peinture" "mozilla/4.7 [en] (win98)"
     161.31.132.118 - - [21\dec\2001:08:42:55-0500] "GET/home.htm HTTP/1.0" 200 4392 "http://fr.search.yahoo.com/fr?p=peinture" "mozilla/4.7 [en] (win98)"
     Columns 1 through 4
     
     '161.31.132.116' ' - - ' '[21\dec\2001' ':08:42:55-0500] '
     '161.31.132.117' ' - - ' '[21\dec\2001' ':08:42:55-0500] '
     '161.31.132.118' ' - - ' '[21\dec\2001' ':08:42:55-0500] '
     
     Columns 5 through 9
     
     '"GET/home.htm' 'HTTP/1.0"' '200' ' 4392 ' [1x30 char]
     '"GET/home.htm' 'HTTP/1.0"' '200' ' 4392 ' [1x30 char]
     '"GET/home.htm' 'HTTP/1.0"' '200' ' 4392 ' [1x30 char]
     
     Columns 10 through 11
     
     '?p=peinture"' '"mozilla/4.7'
     '?p=peinture"' '"mozilla/4.7'
     '?p=peinture"' '"mozilla/4.7'
    c'est tout ce que j'ai pu faire pour le moment, pouvez vous me diriger ou me donner d'autre proposition pour me guider, et pour le moment je suis en train d'essayer de transférer les données du tableau à la base que j'ai déjà crée,

    merci encore infiniment, je suis folle de joie qu'il y a une personne qui s'intéresse a ma question,
    en attendant votre reponse, je vous souhaite bonne journée.

  4. #4
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 36
    Points : 35
    Points
    35
    Par défaut teansfert des donners de matlab a la base de donne
    bonjour ,
    a propos du transfert des donnes de mon tableau a le base, pouvez vous m'aider a faire ce transfert, j'ai deja fait la connexion a la base avec cette instruction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    conn =
     
           Instance: 'connection'
           UserName: 'root'
             Driver: []
                URL: []
        Constructor: [1x1 com.mathworks.toolbox.database.databaseConnect]
            Message: []
             Handle: [1x1 sun.jdbc.odbc.JdbcOdbcConnection]
            TimeOut: 0
         AutoCommit: 'on'
               Type: 'Database Object'
     
    >> a=isconnection(conn)
     
    a =
     
         1
    et a propos du code, je ne sait pas si j'ai obéit ou non!
    mais c'est ce que j'ai compris.

    bon, voila je m'excuse encore une fois, j'attends avec impatience votre réponse, et merci d'avance.

  5. #5
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 53 166
    Points
    53 166
    Par défaut
    Voici une première idée pour lire le fichier log :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [username,access,result,bytes,referrer,user] = textread('test.log','%*15c%3c%*29c%q%d%d%q%q')
    Le code fonctionne avec l'exemple que tu as donné dans ton premier message.
    Il faudra peut être l'adapter... Voir la documentation de TEXTREAD et de FPRINTF pour adapter les formats si besoin.
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  6. #6
    Nouveau membre du Club
    Inscrit en
    Mai 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 36
    Points : 35
    Points
    35
    Par défaut poursuite du travail
    bonsoir Mr dut,
    mérci de m'avoire répondu a ma 1ére question, c'est trés gentil de votre part.
    Sauf que pour le moment je ne sait pas comment transferer mes données a la base de donnée, et d'aprés une petite recheche que je vient de faire, j'ai trouve qu'il était nécessaire de se connéctrer a ma base tout d'abord, alors je suis arriver a le faire, mais j'en ai aucune idée sur l'instruction du transfért ni la forme de la boucle, comme je vient de dire dans dernier msg.
    donc, je serait trés reconnéssante si vous m'aidiez a résoudre mon probléme.
    désolé pour le dérangement et bonne fin de soirée.

Discussions similaires

  1. Réponses: 0
    Dernier message: 16/08/2010, 16h29
  2. Réponses: 9
    Dernier message: 01/02/2010, 20h12
  3. Réponses: 3
    Dernier message: 16/07/2009, 18h00
  4. Réponses: 2
    Dernier message: 21/09/2007, 18h47
  5. Exportation d'un fichier Excel vers une base de données Access
    Par bidule123456 dans le forum VBA Access
    Réponses: 5
    Dernier message: 21/09/2007, 14h38

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo