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

VBA Access Discussion :

Problème avec Split


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2008
    Messages : 56
    Par défaut Problème avec Split
    bonjour,
    Je suis entrain de récupérer des données sous forme de liste (liste identifiée par des balises) pour les mettres dans une autre table. Et j'aimerai que chaque élement de la liste contenu dans l'enregistrement devient lui même un enregistrement.
    Exemple du contenu du champ (tSr.Fields("sr_nom")) qui est une liste de référence:
    <ul><li>ACGIH, American Conference of Governmental Industrial Hygienists<br /><link http://www.acgih.org/TLV/>http://www.acgih.org/TLV/</link></li></ul>
    <ul><li>Annexe VI (Classification et étiquetage harmonisés pour certaines substances dangereuses) du règlement (CE) n° 1272/2008 du 16 décembre 2008 relatif à la classification, à l'étiquetage et à l'emballage des substances et des mélanges</li></ul>
    <ul><li>ATSDR, Agency for Toxic Substances and Disease Registry,Toxicological profile for 1,3-Butadiene (mise à jour avril 1993)<br /><link http://www.atsdr.cdc.gov/>http://www.atsdr.cdc.gov/</link></li></ul>
    <ul><li>CHRIS database, Chemical Hazards Response Information System</li></ul>
    <ul><li>CIRC, Centre International de Recherche sur le Cancer, Monographies Vol 71, Vol 97 (2008)<br /><link http://monographs.iarc.fr/FR/Classification>http://monographs.iarc.fr/FR/Classification</link></li></ul>
    <ul><li>ESIS, European chemical substances information system<br /><link http://ecb.jrc.ec.europa.eu/esis/>http://ecb.jrc.ec.europa.eu/esis/</link> </li></ul>
    <ul><li>INERIS, Fiche de données toxicologiques et environnementales : 1,3-butadiène (mise à jour 18/12/2006) <br /><link http://www.ineris.fr/substances/fr/>http://www.ineris.fr/substances/fr/</link></li></ul>
    <ul><li>INRS, Fiche toxicologique N° 241 (FT 241), 1,3-Butadiène&nbsp;(mise à jour 2002)<br /><link http://www.inrs.fr/>http://www.inrs.fr/</link></li></ul>
    <ul><li>IPCS INCHEM database, International Programme on Chemical Safety, Environmental Health Criteria<br /><link http://www.inchem.org/>http://www.inchem.org/</link> </li></ul>
    <ul><li>NIOSH, Fiche Internationale de Sécurité Chimique n° 0017 (mise à jour 2000)<br /><link http://www.cdc.gov/niosh/ipcsnfrn/nfrnicsc.html>http://www.cdc.gov/niosh/ipcsnfrn/nfrnicsc.html</link> </li></ul>
    <ul><li>US EPA, United States Environmental Protection Agency <br /><link http://www.epa.gov/>http://www.epa.gov/</link> </li></ul>
    Je prend comme séparteur la balise "</Li>" sachant que j'obtient les types type d'erreur quelque soit le séparateur.

    Le code que j'utilise est le suivant:
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    Set tSr = db.OpenRecordset("select * from tmp_sources ", dbOpenDynaset)
    Set Sr = db.OpenRecordset("source_tmp")
    tSr.MoveFirst
     
    Do Until tSr.EOF
        Dim monTab() As String
        Dim i As Integer, j As Integer
     
        monTab = Split(tSr.Fields("sr_nom"), "</li>")
     
        For i = 0 To UBound(monTab)
            For j = 0 To LBound(monTab)
                Sr.AddNew
                Sr.Fields("sr_id") = "999" & numeroSr
                Sr.Fields("sr_type") = 1
                Sr.Fields("sr_nom") = monTab(j)
                Sr.Fields("sr_indice_conf") = 1
                Sr.Fields("sr_agent") = -1
                Sr.Fields("sr_contact") = -9
                Sr.Fields("sr_reference") = monTab(j)
                Sr.Fields("sr_wsys_sb_nom") = tSr.Fields("sb_nom")
     
                Sr.Fields("sr_wsys_user") = "adminCMR"
                Sr.Fields("sr_wsys_date") = Date
                Sr.Update
                numeroSr = numeroSr + 1
            Next j
        Next i
    DoEvents
    tSr.MoveNext
    Loop
    Le programme trourne. Cependant mes résultats ne sont pas correctes car c'est la première valeur issue de la séparation qui est enregistrée autant de fois que qu'il a ya de ligne de tableau.
    Merci de votre aide

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2008
    Messages : 56
    Par défaut
    Bonjour,
    J'ai pu résoudre le problème.
    En effet j'ai modifier la chaine séparateur.
    Le code est :
    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
    monTab = Split(tSr.Fields("sr_nom"), "<ul><li>")
     
        For i = 1 To UBound(monTab)
                Sr.AddNew
                Sr.Fields("sr_id") = "999" & numeroSr
                Sr.Fields("sr_type") = 1
                Sr.Fields("sr_nom") = monTab(i)
                Sr.Fields("sr_indice_conf") = 1
                Sr.Fields("sr_agent") = -1
                Sr.Fields("sr_contact") = -9
                Sr.Fields("sr_reference") = monTab()
                Sr.Fields("sr_wsys_sb_nom") = tSr.Fields("sb_nom")
     
                Sr.Fields("sr_wsys_user") = "adminCMR"
                Sr.Fields("sr_wsys_date") = Date
                Sr.Update
                numeroSr = numeroSr + 1
        Next i

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Petit problème avec split
    Par Hekinox dans le forum C#
    Réponses: 7
    Dernier message: 16/12/2011, 09h35
  2. [Débutant] Problème avec Split
    Par crimetime dans le forum C#
    Réponses: 5
    Dernier message: 14/06/2010, 16h41
  3. Problème avec Split VBA ACCESS
    Par mmmxtina dans le forum VBA Access
    Réponses: 7
    Dernier message: 05/06/2009, 08h31
  4. [Tableaux] problème avec la fonction split()
    Par Marcus15 dans le forum Langage
    Réponses: 3
    Dernier message: 26/02/2007, 11h17
  5. problème avec Split
    Par Empty_body dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 13/12/2006, 15h23

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