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 :

Conversion Latin-1 pour console. [AC-2002]


Sujet :

VBA Access

  1. #1
    Futur Membre du Club
    Inscrit en
    Juin 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 10
    Points : 8
    Points
    8
    Par défaut Conversion Latin-1 pour console.
    Bonjour,
    j'ai crée un beau petit programme qui envoie des messages netsend entre postes. Malheureusement, la langue française comporte des accents "È" qui ne peuvent s'afficher dans le service de message windows car il utilise le typer de texte Latin-1, et la console utilise le type ASCII. Comment puis-je transformer un texte en type Latin-1 pour que les accents fonctionnent?

    Le rapport avec VB est que l'utilisateur entre un texte dans un textbox, puis en clickant sur send, un .bat est créé et exécuté. (Je sais, c'est lourd mais c'est le seul moyen avec la sécurité ici).

    Edit: Aceess 2002, pas dotnet. Dsl pour la mauvaise section du post.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Citation Envoyé par pasdoy Voir le message
    et la console utilise le type ASCII
    Sûrement pas ASCII, sinon on ne pourrait jamais afficher d'accents dans la console... ça utilise l'encodage ibm850 (du moins sous Windows XP en français)

    Pour écrire ton fichier bat, il faut donc utiliser cet encodage :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim ibm850 = Encoding.GetEncoding("ibm850")
    Using writer As New StreamWriter(cheminDuFichier, ibm850)
     
        writer.WriteLine(...)
     
    End Using

  3. #3
    Futur Membre du Club
    Inscrit en
    Juin 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Salut voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    ' Création & Écritue dans le fichier
    Set fs = CreateObject("Scripting.FileSystemObject")
    Set a = fs.CreateTextFile("mess.bat", True)
    a.Close
    F = FreeFile
    Open "mess.bat" For Append As #F
    Print #F, Envoi
    Close #F
    Je ne crois pas que cette solution puisse s'appliquer a mon problème.

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Ah ok, le sujet a été déplacé dans Access.... Ma solution supposait que c'était du VB.NET, donc effectivement elle ne s'applique pas.

  5. #5
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 768
    Points
    7 768
    Par défaut
    Bonjour,

    Essaie ceci.

    Ajoute cette déclaration de la fonction API CharToOem :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Declare Function CharToOem Lib "user32" Alias "CharToOemA" ( _
        ByVal strIn As String, _
        ByVal strOut As String) As Long
    Exemple d'utilisation :
    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
    Sub TestCharOem()
    Dim fl As Integer
    Dim strRow, strRowOem As String
     
    fl = FreeFile()
    Open "C:\Chemin\Test.bat" For Output As #fl
    ' Ligne 1
    strRow = "@Echo Off"
    Print #fl, strRow
    ' Ligne 2
    strRow = "Echo é-è-à-ç"
    strRowOem = String(Len(strRow), vbNullChar)
    CharToOem strRow, strRowOem
    Print #fl, strRowOem
    '
    Close #fl
    End Sub
    A+

  6. #6
    Futur Membre du Club
    Inscrit en
    Juin 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Salut,
    Avec les examens et tout je m'étais absenté du boulot depuis longtemps. Ta solution fonctionne parfaitement merci beaucoup a toi! Par contre j'aimerais bien comprendre cette ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    strRowOem = String(Len(strRow), vbNullChar)
    À quoi sert-elle? Je me suis rendu compte de son importance, est-ce pour le nombre de caractères dans la chaine?

  7. #7
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 768
    Points
    7 768
    Par défaut
    Bonjour,
    Citation Envoyé par pasdoy Voir le message
    j'aimerais bien comprendre cette ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    strRowOem = String(Len(strRow), vbNullChar)
    À quoi sert-elle? Je me suis rendu compte de son importance, est-ce pour le nombre de caractères dans la chaine?
    Oui, ça sert à remplir la chaîne de caractères Visual Basic, avant d'appeler la fonction de l'API Windows.
    Il faut que chaîne VB ait réservé un espace suffisant, correspondant au nombre de caractères que la fonction API va renvoyer.
    C'est dû au fait que l'API Windows est constituée en grande partie, de fonctions destinées au langage C, dans lequel il n'y a pas de type String.
    En C, les chaînes de caractères sont juste des tableaux de caractères.
    On ne connait que l'adresse du premier caractère, et la fin de chaîne de caractères est repérée par le code 00.

    A+

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

Discussions similaires

  1. [VisualStudio 2005 Pro] Template pour Console en C
    Par dorian833 dans le forum Visual C++
    Réponses: 2
    Dernier message: 21/02/2007, 11h27
  2. conversion de texte pour validation W3C
    Par nixonne dans le forum Langage
    Réponses: 1
    Dernier message: 31/10/2006, 23h53
  3. [Conversion]Comment faire pour couper un Double trop long?
    Par dessinateurttuyen dans le forum Général Java
    Réponses: 1
    Dernier message: 13/11/2005, 02h22
  4. Réponses: 6
    Dernier message: 06/10/2005, 16h02
  5. [D7] Conversion d'une application console en ISAPI
    Par Magnus dans le forum API, COM et SDKs
    Réponses: 1
    Dernier message: 28/09/2005, 14h27

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