gpt4 book ai didi

c++ - 阅读巨大的文本

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:05:35 25 4
gpt4 key购买 nike

我正在尝试读取一个文件,就像我在 Linux 中使用选项 more 一样。我只是想对 more 进行几乎相同的实现。我的问题是当我按如下顺序读取文件时:

aaaaaaaaaaaaaaaaaaaa

bbbbbbbbbbbbbbbbbbbbb
.....................
ccccccccccccccccccccc

例如:我在 txt.file 中有 100 个字符串,按照我向您展示的顺序排列。所以每个字符串都不会超过控制台的水平大小并且在 ENTER 之后。

该程序运行良好。我的意思是,如果我的 txt.file 信息没有完全显示,我只需按 SPACE 并在另一个屏幕上看到我的文件信息。

但是如果我放入一个带有长字符串的大文本,它只会完整地读取一个文件并显示文件的结尾。我做错了什么?我可能不考虑控制台的水平尺寸吗?但我认为,在这种情况下,Linux 会替我考虑。你能帮我解决这个问题吗?

我的论点是:./more 0 1.txt

./more - 生成文件,0 - 我从这个字符串开始,1.txt - 文件名。

我的代码:

#include <iostream>
#include <fstream>
#include <vector>
#include <string>
#include <sys/ioctl.h>
#include <unistd.h>
#include <termios.h>


int getch();
void printRecord(int& numStr,struct winsize w, std::vector<std::string>& lines);

int main(int argc, char *argv[]) {
struct winsize w;
char ch;
ioctl(STDOUT_FILENO, TIOCGWINSZ, &w);
std::ifstream readRecord;
std::vector<std::string> lines;

std::string str;
readRecord.open(argv[2]);
int numStr= atoi(argv[1]);

while (!readRecord.eof())
{
getline(readRecord, str);
str.size();
lines.push_back(str);
}
printRecord(numStr,w, lines);

ch=getch();

while(ch!='q'){
if (ch==32)
{
numStr--;
printRecord(numStr,w,lines);
}

if (numStr>=lines.size()){
break;}
ch=getch();
}

return 0;
}

void printRecord(int& numStr,struct winsize w,std::vector<std::string>& lines)
{

for (int i = numStr; i < numStr + w.winsize::ws_row-1; i++)
{

if (i>=lines.size())
break;
else
std::cout << lines[i] << std::endl;

}

numStr += w.winsize::ws_row;
}

int getch()
{
int ch;

struct termios oldt, newt;
tcgetattr( STDIN_FILENO, &oldt );
newt = oldt;
newt.c_lflag &= ~( ICANON | ECHO );
tcsetattr( STDIN_FILENO, TCSANOW, &newt );
ch = getchar();
tcsetattr( STDIN_FILENO, TCSANOW, &oldt );

return ch;
}

最佳答案

不,Linux 不会“在这种情况下为我思考”。如果您的代码按原样打印出文件的内容,那么文件的内容将打印到标准输出。如果终端不够大,无法显示文件内容,那么最后只会保留适合屏幕的内容。随着文件内容的打印,文件的初始部分将短暂出现,然后显示滚动关闭。

终端不会自动为您对程序的输出进行分页。这才是真正的 more 的工作。如果您想复制 more 的功能,您必须自己动手。

您的程序可以通过TIOCGWINSZ ioctl 获取终端显示的大小,as explained in the tty_ioctl(4) manual page ,你应该阅读。获得终端的大小后,您的程序将计算屏幕上可以容纳多少文件内容,并正确分页。

如果您必须处理多字节 UTF-8 编码内容,事情就会变得相当复杂,更不用说如果您的输出包含某些亚洲字符集,则双宽字符。在国际化和本地化时代,计算打印文本的实际大小出奇地困难。但是,对于纯拉丁文本,这应该足够了。您还应该为 SIGWINCH 设置一个信号处理程序,如该手册页中所述,以检测终端大小的变化,以便您可以相应地重新分页文件的内容。

您还可以考虑使用更高级别的库,例如 curses ,在这种情况下可能会有用。

关于c++ - 阅读巨大的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42299123/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com