FORUM DE DISCUSSION SUR LE LANGAGE PANORAMIC

Développement d'applications avec le langage Panoramic
 
AccueilAccueil  FAQFAQ  RechercherRechercher  S'enregistrerS'enregistrer  MembresMembres  GroupesGroupes  Connexion  
Derniers sujets
» Une autre façon de terminer une application.
par Francis-mr Aujourd'hui à 12:07

» Compilateur FBPano
par jean_debord Aujourd'hui à 10:09

» Copier / coller du texte à partir de la fenêtre de commandes
par jean_debord Aujourd'hui à 9:46

» COMPILATEUR V 0.9 beta 8 du 18 aout 2017
par papydall Aujourd'hui à 5:01

» Mettre en windows en veille
par papydall Aujourd'hui à 4:15

» Stretch_on ne stretch plus...
par papydall Hier à 15:22

» Pb 18 (en analyse): RESTORE_LABEL avec DATA à la fin
par Jack Hier à 13:21

» Problème de traitement des opérateurs avec le compilateur.
par Pedro Alvarez Sam 19 Aoû 2017 - 20:01

» Pb 17 (résolu): ITEM_SELECT ne fonctionne pas
par Jack Jeu 17 Aoû 2017 - 19:26

» un nouveau editeur panobasic
par Jean Claude Jeu 17 Aoû 2017 - 10:18

» Le compilateur.
par Pedro Alvarez Jeu 17 Aoû 2017 - 8:36

» Pb 16 (résolu): ON_CLOSE plante à l'exécution
par Jack Mer 16 Aoû 2017 - 20:00

» Pb 15 (résolu): TIMER_ON plante à l'exécution
par Jack Mer 16 Aoû 2017 - 19:58

» KGF_dll - nouvelles versions
par Yannick Dim 13 Aoû 2017 - 17:35

» probleme d'outil
par Yannick Dim 13 Aoû 2017 - 17:32

Navigation
 Portail
 Index
 Membres
 Profil
 FAQ
 Rechercher
Rechercher
 
 

Résultats par :
 
Rechercher Recherche avancée
Août 2017
LunMarMerJeuVenSamDim
 123456
78910111213
14151617181920
21222324252627
28293031   
CalendrierCalendrier

Partagez | 
 

 Chargement d'un très gros fichier.

Voir le sujet précédent Voir le sujet suivant Aller en bas 
AuteurMessage
pan59

avatar

Nombre de messages : 367
Age : 60
Localisation : Wattignies
Date d'inscription : 16/10/2011

MessageSujet: Chargement d'un très gros fichier.   Lun 21 Jan 2013 - 16:04

Bonjour à tous.

Je vous livre une astuce que vous pouvez éventuellement utiliser pour rechercher un item dans un fichier volumineux.

Le code suivant m'a été donné par Klaus.

Le fichier doit d'abord être trié avant utilisation, mais seulement grâce au code suivant.

Ensuite, il vous est possible de rechercher un élément quelconque, grâce à la méthode 'SearchStringList'.

Cette recherche est très rapide.

Le chargement du fichier étant lui-même très rapide (2 sec pour un fichier de 173.000 éléments, au lieu de 21 sec avec un objet List).

Code:
label chercher
Dim res%, index%
Dim a$, b$, mot$, separateur$, parenthese_gauche$, parenthese_droite$
separateur$=chr$(61)

mot$="Katze(féminin) (f)"

parenthese_gauche$=chr$(40)
parenthese_droite$=chr$(41)

width 0,700

edit 2 : top 2,200 : width 2,200
button 3 : top 3,250
caption 3,"Chercher" : on_click 3,chercher

dll_on "kgf.dll"

print "Chargement du dictionnaire en cours..."

dlist 999
sort_on 999
a$ = "dico_français_allemand.txt"
file_load 999,a$
' Enregistrement du dico trié.
file_save 999,a$

res% = dll_call1("CreateStringList",1)
res% = dll_call2("LoadStringList",1,adr(a$))
message "Dictionnaire: "+str$(res%)+" lignes"

end

chercher:
  a$ = trim$(mot$)+" "+separateur$
  b$ = string$(255," ")
  index% = dll_call3("SearchStringList",1,adr(a$),adr(b$))
  b$ = trim$(b$)
  message str$(index%)+": "+b$
  return

Revenir en haut Aller en bas
Voir le profil de l'utilisateur
Klaus

avatar

Nombre de messages : 10062
Age : 68
Localisation : Ile de France
Date d'inscription : 29/12/2009

MessageSujet: Re: Chargement d'un très gros fichier.   Lun 21 Jan 2013 - 16:40

Petit complément d'information:

La fonction CreateStringList a été modifiée dans la version actuellement en ligne sur MyDrive !
Son appel est maintenant:
Code:
res% = dll_call2("CreateStringList",Numero%,Mode%)

Numero% donne le numéro de ls StringList b(entre 1 et 20)
Mode% détermine si la liste est triée ou non. La valeur 1 indique que la liste est toujours triée, et toute autre valeur indique que la liste n'est pas triée.

Si l'on a créé la liste avec Mode%=1, la fonction LoadStringList trie automatiquement la liste après le chargement. Dans ce cas, il n'est plus nécessaire le trier la liste au préalable.

Mais: puisque le programme "sait" maintenant si la liste est triée ou pas, la fonction SearchStringList utilise la méthode de recherche ultra-rapide si la liste est triée, et une méthode plus lente si la liste n'est pas triée.

Je reprends donc le code de Pan59 pour le rendre conforme à la version actuelle de KGF.dll:
Code:
label chercher
Dim res%, index%
Dim a$, b$, mot$, separateur$, parenthese_gauche$, parenthese_droite$
separateur$=chr$(61)

mot$="Katze(féminin) (f)"

parenthese_gauche$=chr$(40)
parenthese_droite$=chr$(41)

width 0,700

edit 2 : top 2,200 : width 2,200
button 3 : top 3,250
caption 3,"Chercher" : on_click 3,chercher

dll_on "kgf.dll"

print "Chargement du dictionnaire en cours..."

' les lignes suivantes sont maintenant inutiles:
' dlist 999
' sort_on 999
' a$ = "dico_français_allemand.txt"
' file_load 999,a$
' ' Enregistrement du dico trié.
' file_save 999,a$
' fin des lignes inutiles

res% = dll_call2("CreateStringList",1,1) : ' passé à 2 paramètres avec l'option "liste triée"
res% = dll_call2("LoadStringList",1,adr(a$))
message "Dictionnaire: "+str$(res%)+" lignes"

end

chercher:
  a$ = trim$(mot$)+" "+separateur$
  b$ = string$(255," ")
  index% = dll_call3("SearchStringList",1,adr(a$),adr(b$))
  b$ = trim$(b$)
  message str$(index%)+": "+b$
  return


C'est vrai: la performance dans la recherche est bluffante.
Revenir en haut Aller en bas
Voir le profil de l'utilisateur http://klauspanoramic.comxa.com/index.html
pan59

avatar

Nombre de messages : 367
Age : 60
Localisation : Wattignies
Date d'inscription : 16/10/2011

MessageSujet: Chargement d'un très gros fichier.   Lun 21 Jan 2013 - 16:43

Bonjour.

Oui, autant pour moi, il manquait le 3è paramètre à la fonction.

Pour la recherche d'un élément, j'utilise la sub suivante, à adapter suivant vos besoins:


Code:
sub chercher(element$, numero_objet_liste%)

    ' Recherche un élément dans un objet de type LIST.
    ' On passe une chaîne de caractères en paramètre qui représente le début de l'élément recherché.
    ' On peut chercher également l'élément exact.
    ' La recherche est insensible à la casse.
    ' L'objet LIST ciblé peut être un objet Panoramic, dans n'importe quelle fenêtre, ou alors un objet LIST d'une application externe, Panoramic ou non.

    ' 0 = la recherche aboutit si le début d'un élément correspond au critère
    ' 1 = la recherche aboutit si l'élément en sa totalité corrrespond au critère
    ' res% fournit 0 si l'élément n'est pas trouvé.

    if instr(sens_traduction_texte$,"allemand")>0 and numero_objet_liste%=999
      temporaire$ = string$(255," ")
      res% = dll_call3("SearchStringList",1,adr(element$),adr(temporaire$))

      ' temporaire$=trim$(left$(trim$(temporaire$),instr(trim$(temporaire$),separateur$)))
      if left$(temporaire$,len(element$))<>element$ then res%=0

          else

      hnd% = handle(numero_objet_liste%)
      res% = dll_call3("SearchListBox",hnd%,0,adr(element$))
    end_if

end_sub
Revenir en haut Aller en bas
Voir le profil de l'utilisateur
Contenu sponsorisé




MessageSujet: Re: Chargement d'un très gros fichier.   

Revenir en haut Aller en bas
 
Chargement d'un très gros fichier.
Voir le sujet précédent Voir le sujet suivant Revenir en haut 
Page 1 sur 1
 Sujets similaires
-
» Texte d'attente pendant chargement fichier swf
» Très gros problème /!\
» très gros ralentissement de mon forum
» Très gros retard sur la réception de mp
» Chargement des pages très lent

Permission de ce forum:Vous ne pouvez pas répondre aux sujets dans ce forum
FORUM DE DISCUSSION SUR LE LANGAGE PANORAMIC :: PANORAMIC 32 bits :: Vos sources, vos utilitaires à partager-
Sauter vers: