Excelファイルの作成を支援するクラスを作成しています(2番目の質問)。特定の行と列の場所にセルを作成し、それを配列に保存するメンバー関数があります。
ExcelSheet::SetValue(int row, int column, std::string szValue) {
myWorksheet[row][column] = szValue;
}
しかし、Excelのように、列を文字と数字の組み合わせとして指定するオプションを使用して、その関数をオーバーロードしています。「A3」のような入力を行3列1に、またはAB19を行19列28に変換できるようにしたい。IE、
ExcelSheet::SetValue(std::string szCell, std::string value) {
// search for the alphabetical part of szCell using regex and
// convert it to a column number
myWorksheet[row][column] = szValue;
}
Excelの列パターンは次のようになります。
A, B, C, D, E... Z (1-26)
AA, AB, AC, AD, AE... AZ (27-52)
BA, BB, BC, BD, BE... BZ (53-78)
...
ZA, ZB, ZC... ZZ
AAA, AAB, AAC... AAZ
ABA, ABB, ABC... ABZ
...
AZA, AZB, AZC... AZZ
BAA, BAB, BAC... BAZ
...
ですから、ある種の26ベースのループでうまくいくと思いますが、それを実装する場合、どこから始めればよいのかさえわかりません。
アップデート:
私のほぼ機能しているコード:コンパイルされますが、何らかの理由で行が正しく取得されません。
#include <vector>
#include <string>
#include <iostream>
#include <regex>
class VectorClass {
std::vector<std::string> vectorString;
public:
void PrintVector(std::string szValue) {
std::string str = "space";
vectorString.push_back(szValue);
vectorString.push_back(str);
std::cout << "Loop:" << std::endl;
for(int i=0; i < vectorString.size(); i++) {
std::cout << vectorString[i] << std::endl;
}
}
int GetColumn(std::string szValue) {
std::regex rgx("^([a-zA-Z]+)");
std::smatch result;
if( regex_search(szValue, result, rgx) ) {
std::string szResult = result[0];
int numletters = szResult.length();
const char * colstr = szResult.c_str();
//char colstr[5];
//int numofletters = 0;
//for(int n=0;n<szResult.length();n++) {
// colstr[n] = szResult.substr(n,1);
// numofletters++;
//}
//char colstr[]="AEF";
int col=0;
for(int i=0; i<numletters; i++) {
col = 26*col + colstr[i] - 'A' + 1;
}
return col;
//return atoi(szResult.c_str());
}
else
return -1;
}
int GetRow(std::string szValue) {
std::regex rgx("^[a-zA-Z]+(\d+)$");
std::smatch result;
if( regex_search(szValue, result, rgx) ) {
std::cout << "test: " << result.size() << std::endl;
for(size_t i=0; i<result.size(); ++i) {
std::cout << result[i] << std::endl;
}
std::string szResult = result[0];
return atoi(szResult.c_str());
}
else
return -1;
}
};
int main () {
VectorClass myclass;
//myclass.PrintVector("ship");
std::cout << "A1 = Column " << myclass.GetColumn("A1") << ", Row " << myclass.GetRow("A1") << std::endl;
std::cout << "B32 = Column " << myclass.GetColumn("B32") << ", Row " << myclass.GetRow("B32") << std::endl;
std::cout << "Z65 = Column " << myclass.GetColumn("Z65") << ", Row " << myclass.GetRow("Z65") << std::endl;
std::cout << "AA12 = Column " << myclass.GetColumn("AA12") << ", Row " << myclass.GetRow("AA12") << std::endl;
std::cout << "AB366 = Column " << myclass.GetColumn("AB366") << ", Row " << myclass.GetRow("AB366") << std::endl;
std::cout << "FAB43 = Column " << myclass.GetColumn("ZAB43") << ", Row " << myclass.GetRow("ZAB43") << std::endl;
std::cout << "ZZZ43456 = Column " << myclass.GetColumn("XDE43456") << ", Row " << myclass.GetRow("XDE43456") << std::endl;
std::cin.get();
return 0;
}