Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

ACCESS 97 : SUBSTITUTIONS POUR MID/MID$ ; WORKSHEETFUNCTION.MIN ; WORKSHEETFUNCTION.MAX


Information sur la source

Description

Normalement, il ne serait pas nécessaire d'écrire ces procédures, mais il semble que :
1 - Mid/Mid$ (extraction d'une sous-chaine) ne soit pas implémentée sous access 97
2 - utilisant Excel, je peux appeler "WorkSheetFunction.Min" et "WorkSheetFunction.Min". Or ce ne doit pas être le cas sous access 97. Raison de la présence de ces fonctions de substitution (enfin presque, car ici, ces fonctions ne comparent que 2 valeurs, ce qui est suffisant pour un usage courant et pour le fonctionnement de "Mid/Mid$).
 

Source

  • Attribute VB_Name = "Mid_Acces"
  • ' REDLUPUS 2004 : Procédures de substitution (utilisateurs access):
  • ' Mid/Mid$ ; WorkSheetFunction.Min et WorkSheetFunction.Max
  • Option Explicit
  • ' =====================================
  • Public Function Min(ByVal V1, V2)
  • ' -------------------------------------
  • ' Substitut à la fonction "WorksheetFunction.Min"
  • ' retourne la plus petite des deux valeurs V1 et V2
  • ' =====================================
  • If V1 < V2 Then Min = V1 Else: Min = V2
  • End Function
  • ' =====================================
  • Public Function Max(ByVal V1, V2)
  • ' -------------------------------------
  • ' Substitut à la fonction "WorksheetFunction.Max"
  • ' retourne la plus grande des deux valeurs V1 et V2
  • ' =====================================
  • If V1 > V2 Then Max = V1 Else: Max = V2
  • End Function
  • ' =====================================
  • Public Function Mid1(ByVal St As String, _
  • ByVal Beg As Byte, _
  • ByVal L As Byte) As String
  • ' -------------------------------------
  • ' Substitut à la fonction Mid/Mid$
  • ' Retourne la sous-chaîne de longueur "L",
  • ' extraite de "St", en commençant à la
  • ' position "Beg".
  • ' St chaîne d'origine
  • ' Beg Position de départ
  • ' L longueur à extraire
  • ' =====================================
  • Mid1 = Right$(Left$(St, Beg + L - 1), _
  • Max(0, Min(L, Len(St) - Beg + 1)))
  • End Function
Attribute VB_Name = "Mid_Acces"
' REDLUPUS 2004 : Procédures de substitution (utilisateurs access):
' Mid/Mid$ ; WorkSheetFunction.Min et WorkSheetFunction.Max
Option Explicit

' =====================================
Public Function Min(ByVal V1, V2)
' -------------------------------------
' Substitut à la fonction "WorksheetFunction.Min"
' retourne la plus petite des deux valeurs V1 et V2
' =====================================
If V1 < V2 Then Min = V1 Else: Min = V2
End Function

' =====================================
Public Function Max(ByVal V1, V2)
' -------------------------------------
' Substitut à la fonction "WorksheetFunction.Max"
' retourne la plus grande des deux valeurs V1 et V2
' =====================================
If V1 > V2 Then Max = V1 Else: Max = V2
End Function

' =====================================
Public Function Mid1(ByVal St As String, _
                     ByVal Beg As Byte, _
                     ByVal L As Byte) As String
' -------------------------------------
' Substitut à la fonction Mid/Mid$
' Retourne la sous-chaîne de longueur "L",
' extraite de "St", en commençant à la
' position "Beg".
'   St      chaîne d'origine
'   Beg     Position de départ
'   L       longueur à extraire
' =====================================
Mid1 = Right$(Left$(St, Beg + L - 1), _
              Max(0, Min(L, Len(St) - Beg + 1)))
End Function

Conclusion

Espérant que çà rendra service à "idefixfix", suite à sa question.
 

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Commentaires et avis

signaler à un administrateur
Commentaire de jul00 le 26/05/2005 17:06:39

désolé mais avec moi sa plante sur Right$ et Left$

Ajouter un commentaire



Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,234 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.