Создание карты из ввода значения альтернативного ключа - PullRequest
0 голосов
/ 09 марта 2009

У меня есть данные, которые выглядят так:

>day11:1:356617
ACTTCTGATTCTGACAGACTCAGGAAGAAACCAT
>day11:2:283282
CTCAGCCCGTAGCCCGTCGGTTCCGGAGTAAGTT
>day11:3:205058
NNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
>day11:4:202520
AGTTCGATCGGTAGCGGGAGCGGAGAGCGGACCC
>day11:5:107099
AGGCATTCAGGCAGCGAGAGCAGAGCAGCGTAGA
>day11:6:106715
CTCTTTGCCCCATCTACTGCGAGGATGAAGACCA

Что я хочу сделать, так это создать карту со строкой, начинающейся с ">" как ключ и ACGT в качестве значения.

Однако эта моя конструкция не работает? Карта кажется не в состоянии захватить значение, как я ожидал.

#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <map>
int main() {

     ifstream myfile ("mydata.txt");

    map <string,string>FastaMap;

    cerr << "Read Fasta File to Map" << endl;

    if (myfile.is_open())
    {
        while (getline(myfile,line) )
        {
            stringstream ss(line);
            string Fasta;
            string Header = "";
            string Tag = "";

            ss >> Fasta; // read first column

            if ( Fasta[0] == '>') {
                 // get header only 
                 Header = Fasta.substr(1);
                 //cerr << Header << endl;
            }
            else {
                Tag = Fasta;
            }


            if (Header != "" || Tag != "") {
                FastaMap[Header] = Tag;
                //cout << "TAG: " << Tag << endl;
                //cout << "Head: " << Header << endl;
                // FastaMap.insert(make_pair(Header,Tag));
           }
        }
        myfile.close();
    }
    else  {
        cout << "Unable to open file";
    }

    // This doesn't print the second value, only prints the first

    for (map<string,string>::iterator it = FastaMap.begin(); it!=
            FastaMap.end(); it++) {
         cout << "Head: " << (*it).first << ", End: " << (*it).second << endl;
    }

}

Ожидаемый результат:

Head: day11:1:356617, End: ACTTCTGATTCTGACAGACTCAGGAAGAAACCAT
Head: day11:2:283282, End: CTCAGCCCGTAGCCCGTCGGTTCCGGAGTAAGTT
...etc...

Ответы [ 2 ]

4 голосов
/ 09 марта 2009

Вы очищаете Fasta, Header и Tag каждый цикл. Что вам нужно сделать, это:

  1. Объявите эти переменные вне while (непосредственно перед ним)
  2. Измените строку if (Header != "" || Tag != "") на && вместо || (там есть логическая ошибка)
  3. Сброс переменных Tag и Header при добавлении их на карту.

Правильный код:

#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <map>
using namespace std;
int main() {
        string line;
        ifstream myfile ("test");

        map <string,string> FastaMap;

        cerr << "Read Fasta File to Map" << endl;

        if (myfile.is_open())
        {
                string Fasta;
                string Header = "";
                string Tag = "";
                while (getline(myfile,line) )
                {

                        stringstream ss(line);

                        ss >> Fasta; // read first column

                        if ( Fasta[0] == '>') {
                                // get header only
                                Header = Fasta.substr(1);
                                //cerr << Header << endl;
                        }
                        else {
                                Tag = Fasta;
                        }


                        if (Header != "" && Tag != "") {
                                FastaMap[Header] = Tag;
                                cout << "TAG: " << Tag << endl;
                                cout << "Head: " << Header << endl;
                                Header = "";
                                Tag = "";
                                // FastaMap.insert(make_pair(Header,Tag));
                        }
                }
                myfile.close();
        }
        else  {
                cout << "Unable to open file";
        }

        // This doesn't print the second value, only prints the first

        for (map<string,string>::iterator it = FastaMap.begin(); it!=
                     FastaMap.end(); it++) {
                cout << "Head: " << (*it).first << ", End: " << (*it).second << endl;
        }

}

Обратите внимание, что в коде есть и другие возможные улучшения, но теперь он работает.

1 голос
/ 09 марта 2009

Ошибка, если: if (Header! = "" || Tag! = "") должно быть: if (Header! = "" && Tag! = "")

Еще больше:

if (Header != "" && Tag != "") {
                    FastaMap[Header] = Tag;
                    Header = "";
                    Tag = "";
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...