Привет, так что этот код работал 5 минут назад, чтобы сделать именно то, что мне нужно было сделать.
Данные:
Set Field [G],Sheet Resistivity (Gavg) [ohm/sqr]
0.0000E+0,
0.0000E+0,7.270620E+2
1.0000E-2,
1.0000E-2,7.271280E+2
-1.0000E-2,
-1.0000E-2,
-1.0000E-2,7.271290E+2
И мой код для этого:
#include <iostream>
#include <fstream>
using namespace std;
int main(){
ifstream ip("/Users/10Exahertz/Documents/Hall Data/Test/data.txt");
if(!ip.is_open()) std::cout << "ERROR: File Open" << '\n';
string x;
string y;
while(getline(ip,x,',')){
getline(ip,y,'\n');
if(y!="")
std::cout <<x<<","<< y << '\n';
}
ip.close();
}
Как я сказал 5 минут назад, это сработало, оно избавилось от строк с пустой строкой y, и все было хорошо. Но потом я вернулся к исходному файлу данных, и он там не работал. Я был сбит с толку, поэтому я поместил исходные данные в data.txt, и теперь они тоже не работают. Я честно запутался, но что было бы лучшим условием в том, чтобы цикл работал так, чтобы это работало.
Похоже, у вас могут быть пробелы. Я бы использовал решение из этот ответ обрезать пустое пространство от вашего y
Строка просто для уверенности:
#include <iostream>
#include <algorithm>
#include <cctype>
#include <locale>
#include <fstream>
using namespace std;
// trim from start (in place)
static inline void ltrim(std::string &s) {
s.erase(s.begin(), std::find_if(s.begin(), s.end(), [](int ch) {
return !std::isspace(ch);
}));
}
int main() {
[...]
while(getline(ip,x,',')){
getline(ip,y,'\n');
ltrim(y);
if(y!="")
std::cout <<x<<","<< y << '\n';
}
}
Других решений пока нет …