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

C Discussion :

Transtypage d'un int en char


Sujet :

C

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut Transtypage d'un int en char
    Bonjour,

    J'ai un petit soucis. J'ai besoin de recuperer un integer dans un char. Je ne sais pas quelle est la fonction appropriée car j'ai essayé le str ça na pas marché.

    NB: je précise tout de même que c'est un programme écrit en PRO*C d'ORACLE. La recuperation de cette varible en char me permet de l'utiliser dans la partie SQL de mon programme.

    je rajoute le bout de code pour mieux expliquer mon probléme

    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
     
    EXEC SQL BEGIN DECLARE SECTION;
    varchar monvar[12]
     
    EXEC SQL END DECLARE SECTION;
     
     
    int i;
     
    for (i=0; i< 50; i++)
    {
      monvar = i;  //i doit être transformer sinon erreur de transtypage
      {
       strcpy((char*)monvar .arr,monvar );
      monvar.len=(unsigned short)strlen(monvar .arr);
       EXEC SQL update MATABLE set monvar= :monvar
    Merci d'avance

  2. #2
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par hadid
    J'ai un petit soucis. J'ai besoin de recuperer un integer dans un char. Je ne sais pas quelle est la fonction appropriée car j'ai essayé le str ça na pas marché.
    Que veux tu dire par 'en char ?' En chaine de caractères ? Si c'est le cas, sprintf() est ton ami.

    Evidemment, le tableau de char contenant la chaine de destination doit être suffisamment grand...

  3. #3
    Membre confirmé Avatar de toxcct
    Développeur informatique
    Inscrit en
    Juillet 2006
    Messages
    434
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 434
    Points : 511
    Points
    511
    Par défaut
    tu as juste à assigner ton char avec la valeur de l'int.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    int i = 54;
    char = i;     //contien le caractere dont le code ascii est 54
    bien sur, tu dois faire attention aux dépassements de capacité...

  4. #4
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut
    au fait comme je disais tantôt, ma variable qui reçoit la transformation de l'integer et du type varchar2

  5. #5
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut
    voici un peu bout de mon programme pour me faire expliquer clairement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    EXEC SQL BEGIN DECLARE SECTION;
    varchar monvar[12]
    
    EXEC SQL END DECLARE SECTION;
    
    
    int i;
    
    for (i=0; i< nbre; i++)
    {
    monvar je lui affecte la valeur i

  6. #6
    Membre expérimenté
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Points : 1 729
    Points
    1 729
    Par défaut
    Attends, tu melanges du SQL et du C?

  7. #7
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut
    le sprintf ne marche pas. Peut être je m'y prend mal !

  8. #8
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut
    oui je mélange du SQL et du C. C'est du PRO*C.

  9. #9
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par Gruik
    Attends, tu melanges du SQL et du C?
    Bienvenu dans le monde bizarre de PRO*C...

  10. #10
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par hadid
    le sprintf ne marche pas. Peut être je m'y prend mal !
    Probablement. On est censés deviner ce que tu fais, où tu as l'intention de poster ton code ?

  11. #11
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut
    Mon bout de code le voici:

    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
    EXEC SQL BEGIN DECLARE SECTION;
    [B]varchar monvar[/B][12]
    
    EXEC SQL END DECLARE SECTION;
    
    
    int i;
    
    for (i=0; i< nbre; i++)
    {
      monvar = i;  //i doit être transformer sinon erreur de transtypage
      {
       strcpy((char*)monvar .arr,monvar );
      monvar.len=(unsigned short)strlen(monvar .arr);
    
       EXEC SQL update MATABLE set monvar= :monvar

  12. #12
    Membre éclairé Avatar de homeostasie
    Homme Profil pro
    Inscrit en
    Mai 2005
    Messages
    939
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 939
    Points : 862
    Points
    862
    Par défaut
    Je ne connais pas le PRO*C mais je dirais que tu as définit un tableau de char de 12 caractères:
    et tu l'utilises pas comme il convient:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    for (i=0; i< 50; i++)
    {
       monvar = i; //i doit être transformer sinon erreur de transtypage
    {
    J'aurais plutot fait quelque chose comme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for (i=0; i< 12; i++)
    {
       monvar[i] = i; //i doit être transformer sinon erreur de transtypage
    {

  13. #13
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 47
    Points : 23
    Points
    23
    Par défaut
    Au fait dans la table ou je fais mon update monvar est de type number.
    mais tout ce qui ce déclare entre EXEC doit être du type varchar.

    EXEC SQL BEGIN DECLARE SECTION;
    varchar ..
    varchar ..
    varchar ..
    varchar ..
    EXEC SQL END DECLARE SECTION;

    c'est la raison pour laquelle j'ai défini un varchar[12],

    Ce que j'ai pas précisé ce que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    for (i=0; i< 50; i++)
       {
    c'est pas ça exactement dans mon code, c'est plutôt ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    for (i=0; i< nbre; i++)
       {
    et nbre varie selon les cas dans ce que je contrôle voilà.

Discussions similaires

  1. Conversion int en char *
    Par Trunks dans le forum C
    Réponses: 6
    Dernier message: 18/03/2006, 16h44
  2. [debutant] transtypage string en int
    Par melvar dans le forum Langage
    Réponses: 3
    Dernier message: 08/03/2006, 16h08
  3. [C++] Conversion de int en char* ou SetDlgItemText()
    Par lastcheper dans le forum MFC
    Réponses: 3
    Dernier message: 11/04/2005, 17h46
  4. [SQL] Convertir un champ INT en CHAR dans un SELECT ?
    Par webtheque dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 17/03/2005, 14h45
  5. [Transtypage] Long en int
    Par Bugmaster dans le forum Langage
    Réponses: 2
    Dernier message: 20/09/2004, 09h05

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