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 :

extraction de donnees vers vecteur c++


Sujet :

C++

  1. #1
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 10
    Par défaut extraction de donnees vers vecteur c++
    bonjour,


    je suis un stagiaire en salle de marche ayant tres peu d'experience en c++
    j'aimerais savoir comment par exemple extraire une serie de cotations d une action d un fichier excel vers un vecteur c++ afin de pouvoir faire toute sorte d operation sur ces cpottions.
    Je pense qu il faut que je les copie ds un fichier txt, mais apres je suis ds le flou le plus total.
    Quelqun pourrait me renseigner ou me fournir des exemples?
    Merci d'avance

  2. #2
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut

    Une des façon la plus simple de régler ton problème est d'exporter ton fichier excel au format csv. (regarde dans les format de fichier d'excel lorsque tu sauvegardes). Tes données seront séparées par des virgules ,
    Ensuite tu pourras aisément parser ce fichier en C++.
    Tout ce dont tu à besoin ce trouve dans la FAQ c++

    Notamment :
    Comment lire un fichier ligne par ligne
    Comment découper une chaîne en fonction d'un séparateur
    Même avec peu d'expérience tu devraispouvoir t'en sortir avec ces codes.

    Bon courage

  3. #3
    Membre émérite
    Avatar de Spout
    Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2007
    Messages
    904
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Février 2007
    Messages : 904
    Par défaut
    Salut,

    Je pense que pour ton problème tu n'as pas besoin de passer par du C++ (à moins que tu y sois obligé). Tu pourrais alors utiliser/faire directement les macros plus ou moins complexes dans Excel. Le langage utilisé est du VBA, proche du Visual Basic.
    Voir ce forum pour toute question.

    Si tu es toutefois obligé d'utiliser du C++, je pense que le plus simple serait de passer par un fichier CSV. Ton code C++ lirait ensuite ce fichier et en extrairait les données.

    Analyse bien tes besoins (contraintes, moyens, buts) pour décider de la meilleure démarche, à savoir utiliser du C++ ou du VBA. Car si tu extraits des données d'Excel pour faire une série de calculs et les réinsérer dans Excel, mieux vaut l'utiliser totalement. Ca dépend de ton sujet.

  4. #4
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 10
    Par défaut
    merci pour vos reponses
    j ai trouve un code simple qui le fait a partir d un fichier txt
    ce que je veux maintenant,c est mettre chaque ligne ds un vecteur
    pour info je fais mestest a partir du fichier txt suivant
    1
    2
    3
    4
    5

    voici le coe


    #include <iostream>
    #include <fstream>
    #include <string>
    using namespace std;

    int main () {
    string line;
    ifstream myfile ("example.txt");
    if (myfile.is_open())
    {
    while (! myfile.eof() )
    {
    getline (myfile,line);
    cout << line << endl;
    }
    myfile.close();
    }

    else cout << "Unable to open file";

    return 0;
    }

  5. #5
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Très bien. Deux choses:

    1- Tes fichiers excel se présentent-ils uniquement sur une seule colonne ?
    2- Ici tu récupère une chaine (string) et je suppose que tu préfèrerai récupéré des entiers ou des réels pour pouvoir effectuer des traitements mathématiques.
    Créé un vector<int> ou vector<float> et remplie le (avec push_back) en ayant auparavant convertit ta chaine en entier ou flotant.
    Comment convertir une string en un entier

    Ps: pense à la balise code (le # dans l'édition du post) pour que ça soit plus lisible pour nous.

  6. #6
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 10
    Par défaut
    merci pour ces precieux conseils
    cela marche bien, a un detail pres
    toujours a partir d un simple ficier txt contenant juste
    1
    2
    3
    4
    lorsque j ecris un code pour verifier les composantes de mon vecteur, il me rajoute 2 zeros a la fin et comme dernier composantt
    -4.31602e+008
    je pense qu il doit y avoir un probleme au niveau du dernier espace
    pourriez m eclairer sur ce point?
    le code que j'utilise est le suivant

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    #include <iostream>
    #include <fstream>
    #include <string>
    using namespace std;
    #include<vector>
     
    int main(){
     
    vector<float> M;
    string line;
    ifstream myfile ("data.txt");
    if (myfile.is_open())
    {
    while (! myfile.eof() )
    {
    getline (myfile,line);
    float s=atof(line.c_str());
    M.push_back(s);
    //cout << line << endl;
     
    }
    //cout<<M[M.size()-2];
    myfile.close();
    }
     
    else cout << "Unable to open file"; 
     
    //cout<< M.size();
     
     
    for (int y=0;y<=M.size();++y){
    cout<< M[y]<<endl;}
     
     
     
    return 0;
    }
    merci

  7. #7
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Déjà:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for (int y=0;y<M.size();++y){
    cout<< M[y]<<endl;}
    si n=M.size():
    Tu as n élément dans ton tableau donc tu le lis de 0 à n-1;

  8. #8
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 10
    Par défaut
    Encore merci beaucoup
    il reste un 0 a la fin,mais qui senleve facilement a l'aide d un erase
    un autre probleme maintenant
    ds le code ci dessous,il ne semble qu'il n y ait pas d'erreur(du moins apres la compilation), mais des que j'essaie de le run,un message d'erreur apparait du type test.exe (test etant le nom de mon fichier)has encountered a problem and needs to close. We are sorry for the inconvenience.

    Apres quelques modifications successives, je me suis rendu compte que l erreur survient lorsque j enleve les commentaires de tout ce qui touche a mon vecteur log_returns comme cout<<log_returns[0];ou
    //log_returns[0]=2;


    any thoughts?




    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    #include <iostream>
    #include <fstream>
    #include <string>
    using namespace std;
    #include<vector>
    
    int main(){
    
    vector<float> M;
    string line;
    ifstream myfile ("data.txt");
    if (myfile.is_open())
    {
    while (! myfile.eof() )
    {
    getline (myfile,line);
    float s=atof(line.c_str());
    M.push_back(s);
    //cout << line << endl;
    
    };
    //M.erase(M.begin()+M.size()-2,M.begin()+M.size());
    //cout<<M[M.size()-2];
    myfile.close();
    }
    
    else cout << "Unable to open file"; 
    
    //for (int y=0;y<=M.size()-1;++y){
    //cout<< M[y]<<endl;}
    
    
    vector<float> temp;
    //cut<<temp.size();
    vector<float> log_returns;
    cout<<log_returns[0];
    //log_returns[0]=2;
    //for (int j=1;j<=5;++j){
    //temp[j]=M[j-1];
    	//cout<<temp[j]<<endl;
    //;};
    //for (int k=1;j<=M.size()-9;++k){
    	//log_returns[k]=M[k]/temp[k];
    	//cout<<log_returns[k]<<endl;};
    
    
    return 0;
    }

  9. #9
    Membre émérite
    Avatar de Spout
    Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2007
    Messages
    904
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Février 2007
    Messages : 904
    Par défaut
    Tu déclares un vector<float> puis, sans faire aucun ajout, tu demandes à accéder à l'élément [0] alors que ton vecteur est vide.

  10. #10
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 10
    Par défaut
    oui, mais le meme probleme survient aussi lorsque j'essaie d,executer la ligne commentee en dessous ou j'assigne une valeur au premier element du vecteur log-returns
    Je ne comprends pas pourquoi.

  11. #11
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Citation Envoyé par quantanalyst Voir le message
    oui, mais le meme probleme survient aussi lorsque j'essaie d,executer la ligne commentee en dessous ou j'assigne une valeur au premier element du vecteur log-returns
    Je ne comprends pas pourquoi.
    Certes mais ton vector<float> log_returns n'a pas allouer de mémoire. Tu dois le faire dynamiquement avec push_back:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    vector<float> log_returns;
    log_returns.push_back(2.0f);
    cout<<log_returns[0];
    Ou alors si tu connais la taille à l'avance tu peux faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    const int size=10;
    vector<float> log_returns(taille);//allocation de 10 floats en mémoire
    log_returns[0]=2.0f;
    cout<<log_returns[0];

  12. #12
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Combien de fois faudra-t'il repeter qu'on ne teste pas eof avant d'avoir une operation d'entree qui a echoue:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    while (std::getline(is, line)) {
    }
    if (is.bad()) {
         // erreur d'IO
    } else if (!is.eof()) {
        // erreur de formattage
    }
    Pour lire un fichier qui n'a que des doubles (utiliser des floats est vraisemblablement pas une bonne idee) dans un vecteur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    std::vector<double> table;
    std::istream is;
     
    std::copy(std::istream_iterator<double>(is),
              std::istream_iterator<double>(),
              std::inserter(table, table.end()));
    if (is.bad()) {
       ...
    } else if (!is.eof()) {
       ...
    }

  13. #13
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 10
    Par défaut
    Bonour, et merci pour toutes vos reponses.
    J'ai un autre probleme
    Je souhaite resoudre une equation assez compliquee,et pour cela je souhaite utiliser une methode de Newton.
    Le code est assez simple,je le mets ci-dessous pour des fonctions simples
    Ce que je souhaiterais faire,dans la definition de mes vraies fonctions,c'est utiliser ma fameuse matrice M que j 'ai exportee a partir d un fichier (cf le code ds les post precedents pour la maniere dont je la rentre)
    en fait je veux une fonction d une variable et jaimerais que ma matrice soit consideree comme une constante
    j'ai essaye de le faire en dehors du main,cela ne marche pas
    j'ai essaye l instruction define, mais je ne sais pas si on peut le faire pour des matrices
    any thoughts?
    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    #include<cmath>
    #include<iostream>
    using namespace std;
    // the maximum number of iterations
    const int MAXITER    = 100;
     
    // the accepted error
    const double error    = 0.0001;
     
    // the Euler constant
    const double e        = 2.718281828459;
     
    // the function F(x)
    #define F(x) (    pow(x, 2)  )
     
    // the derivative of the function F(x), meaning F`(x)
    #define Fd(x) (  2*x   )
     
     
     
    int NewtonMethodForEquation(double& x)
    {
        int n = 1;
     
        while( ( fabs(F(x)) > error ) && ( n <= MAXITER ) )
        {
            x = x - ( F(x) / Fd(x) );
     
            n++;
        }
     
     
        return n;
    }
     
     
    int main(){
     
    double x;
    int n;
     
     
    cout<<"Newton's method: " << endl << endl;
     
    cout<< "Give the initial approximation: ";
    cin >> x;
     
     
     
    // now we apply Newton's method
    n = NewtonMethodForEquation(x);
     
    if(n > MAXITER)
        cout << "In " << MAXITER << " iterations no solution was found!" << endl;
    else
        cout << "The solution is: " << x << " and it was found in " 
             << n << " iterations" << endl;
    //cout<<(1+sqrt(5))/2;
     
     
    return 0;}

Discussions similaires

  1. [XL-2007] extraction de donnees d'un fichier xml vers excel (vba)
    Par gibba88 dans le forum Excel
    Réponses: 9
    Dernier message: 02/05/2012, 14h29
  2. [VB]Création de donnée vers un ficher txt
    Par cesar33 dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 25/05/2006, 12h49
  3. Réponses: 5
    Dernier message: 05/03/2006, 13h21
  4. donnees d'une base de donnees vers un tableau
    Par matterazzo dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 28/10/2005, 23h05
  5. Extraction information *.txt vers une base de données
    Par Mr Capone dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 12/01/2005, 11h26

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