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
» Panoramic et ses curiosités
par Jean Claude Aujourd'hui à 21:48

» Synedit Parameters
par Jean Claude Aujourd'hui à 21:15

» Utilitaire de suppression de fichiers
par Jean Claude Aujourd'hui à 21:11

» Code à vérifier SVP (Oups ! résolu)
par Jean Claude Hier à 21:16

» Compilateur FBPano
par jean_debord Hier à 9:56

» Bienvenue à Virtualalan !
par UltraVox Hier à 9:18

» Concours de Morpions
par jjn4 Hier à 0:04

» ShortName$(F) [Cloturé]
par papydall Mer 21 Juin 2017 - 16:19

» Remplacer espace par tiret dans noms des dossiers / fichiers
par papydall Mer 21 Juin 2017 - 15:27

» Menu personalisé avec icones et menu contextuel
par Laurent (Minibug) Mer 21 Juin 2017 - 12:44

» La liste des choses à faire ...
par Jack Mar 20 Juin 2017 - 22:49

» Quoi de neuf à propos de Goric 3D ? (@Jack)
par UltraVox Mar 20 Juin 2017 - 21:06

» Nom court et anti fenetre dos
par silverman Mar 20 Juin 2017 - 18:31

» Ludothèque Panoramic
par jjn4 Mar 20 Juin 2017 - 18:09

» Proposition à la communauté
par Yannick Mar 20 Juin 2017 - 15:02

Navigation
 Portail
 Index
 Membres
 Profil
 FAQ
 Rechercher
Rechercher
 
 

Résultats par :
 
Rechercher Recherche avancée
Juin 2017
LunMarMerJeuVenSamDim
   1234
567891011
12131415161718
19202122232425
2627282930  
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 : 59
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 : 9969
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 : 59
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
» [Résolu] Chargement trop long !
» Très gros problème /!\
» très gros ralentissement de mon forum
» Très gros retard sur la réception de mp

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: