计算文件行数最紧凑的方法是什么? 我需要这些信息来创建/初始化矩阵数据结构。
稍后我必须再次浏览该文件并将信息存储在矩阵中。
更新:基于Dave Gamble的。但为什么这不编译? 请注意,该文件可能非常大。所以我尽量避免使用容器 以节省内存。
#include <iostream>
#include <vector>
#include <fstream>
#include <sstream>
using namespace std;
int main ( int arg_count, char *arg_vec[] ) {
if (arg_count !=2 ) {
cerr << "expected one argument" << endl;
return EXIT_FAILURE;
}
string line;
ifstream myfile (arg_vec[1]);
FILE *f=fopen(myfile,"rb");
int c=0,b;
while ((b=fgetc(f))!=EOF) c+=(b==10)?1:0;
fseek(f,0,SEEK_SET);
return 0;
}
答案 0 :(得分:10)
如果您需要“再次返回”的原因是因为您无法继续使用此尺寸,请尝试重新订购您的设置。
即,通读文件,将每行存储在std::vector<string>
或其他内容中。然后你有大小,以及文件中的行:
#include <fstream>
#include <iostream>
#include <string>
#include <vector>
int main(void)
{
std::fstream file("main.cpp");
std::vector<std::string> fileData;
// read in each line
std::string dummy;
while (getline(file, dummy))
{
fileData.push_back(dummy);
}
// and size is available, along with the file
// being in memory (faster than hard drive)
size_t fileLines = fileData.size();
std::cout << "Number of lines: " << fileLines << std::endl;
}
这是一个没有容器的解决方案:
#include <fstream>
#include <iostream>
#include <string>
#include <vector>
int main(void)
{
std::fstream file("main.cpp");
size_t fileLines = 0;
// read in each line
std::string dummy;
while (getline(file, dummy))
{
++fileLines;
}
std::cout << "Number of lines: " << fileLines << std::endl;
}
虽然我怀疑这是最有效的方式。这种方法的好处是能够在你去的时候将行存储在内存中。
答案 1 :(得分:10)
我认为这可能会这样做......
std::ifstream file(f);
int n = std::count(std::istreambuf_iterator<char>(file), std::istreambuf_iterator<char>(), '\n') + 1;
答案 2 :(得分:6)
FILE *f=fopen(filename,"rb");
int c=0,b;while ((b=fgetc(f))!=EOF) c+=(b==10)?1:0;fseek(f,0,SEEK_SET);
c中的答案。 那种紧凑型?
答案 3 :(得分:3)
#include <stdlib.h>
int main(void) { system("wc -l plainfile.txt"); }
答案 4 :(得分:1)
计算'\n'
的实例数。这适用于* nix(\ n)和DOS / Windows(\ r \ n)行结尾,但不适用于仅使用\ r \ n的old-skool Mac(系统9或之前)。我从来没有见过只用\ r作为行结尾的案例,所以我不担心它,除非你知道它会成为一个问题。
编辑:如果您的输入不是ASCII,那么您也可能遇到编码问题。你的输入是什么样的?