c++文件排版(文本文件)

【问题描述】

英文电影中参演人员名单一般以某种方式进行排版显示。给定一个未排版的文件listin.txt,该文件中每行参演人员名单由冒号ldquo:rdquo分隔成前后两部分,但格式杂乱无章,单词(由除空格和水平制表符之外的其它字符构成)之间可能有多个空格或水平制表符分隔。编写程序,要求将其按如下排版规则排版输出到另一个文件listout.txt中:

1.从标准输入整数,作为排版后所有各行冒号在一行中的固定位置,输入的整数肯定大于排版后所有各行冒号前的字符个数,位置从1开始计数;

2.冒号左边的单词串以行头为基准左对齐,左边的最后一个单词与冒号之间以空格填充;冒号右边的单词串以冒号基准左对齐,最后一个单词后只有回车换行符,不再有其它字符;

3.冒号左右两边的单词间都只有一个空格分隔,并且要求冒号两边至少各有一个空格。

假设输入文件中每行字符个数不超过100。

【输入形式】

待排版的参演人员名单从当前目录下的listin.txt文件中读入,表示冒号位置的整数从标准输入读入。

【输出形式】

排版后的参演人员名单输出到当前目录下的listout.txt中。

【输入样例】

假设文件listin.txt内容为:

   Digital Intermediate by :   EFILM 

Supervising    Digital Colorist : STEVEN J. SCOTT  

Second Colorist :ANDREW FRANCIS

 Digital Intermediate Producer:LOAN PHAN

Digital  Intermediate Editor:  DEVON MILLER     

表示冒号固定位置的整数为:

40

【输出样例】

文件listout.txt中的内容应为:

【样例说明】

输入的文件listin.txt中有五行参演人员名单,要求排版后冒号位于第40个字符的位置,按照上述排版规则输出到文件listout.txt中。


思路:

这个题我一开始是自己随便写写,然后交的时候就一直格式错误,格式错误
然后我就在CSDN上寻找灵感,但是我发现关于这个题写的不是很能接受,我左思右想,最终发现了水平制表符是一个大坑,因为我是只考虑了空格的影响,所以说题目一定要看仔细!!!到这里还是一头雾水对吧,无所谓,代码有很多注释

#include <iostream>
#include <fstream>//文件读写必须的头文件
#include <string>
using namespace std;
//一定要考虑水平制表符!!!
//不要只考虑空格!!!
int main()
{
	ifstream ifs("listin.txt", ios::in);
	if (!ifs.is_open())
	{
		cout << "文件打开失败" << endl;
		return 0;
	}//一定要判断能否打开成功,虽然打开不成功也用不了,但是好歹有个提示,不然你都不知道错在哪里
	size_t n;
	cin >> n;
	ofstream ofs("listout.txt", ios::out|ios::trunc);//先清空在读入
	string s,t;
	while (getline(ifs, s))
	{
		t.clear();//每次循环之前需要清空
		size_t pos = s.find(":");//先找出冒号的位置
		for (size_t i = 0; i < pos; i++)
		{
			if (s[i] != ' ' && s[i] != '\t')//如果既不是空格,也不是水平制表符,那就直接写进去
			{
				t += s[i];
			}
			else if (i > 0 && (s[i] == ' ' || s[i] == '\t') && (s[i - 1] != ' ' && s[i - 1] != '\t'))//因为用到了i-1,所以i>0
			//如果该字符是水平制表符或空格,且他前面是个字母,那就加个空格上去,不然就不能加空格,不然格式就不对了
			{
				t += " ";
			}
		}
		size_t num = t.size();//判断t多大,然后用个循环一直加空格加到给定的冒号的位置
		for (size_t i = 0; i < n - num-1; i++)
		{
			t += " ";
		}
		t += ": ";//再把冒号加上
		for (size_t i = pos + 1; i < s.length(); i++)//冒号之后的字符串进行判断,与前面的判断方法一样
		{
			if (s[i] != ' ' && s[i] != '\t')
			{
				t += s[i];
			}
			else if (i > pos+1 && (s[i] == ' ' || s[i] == '\t') && (s[i - 1] != ' ' && s[i - 1] != '\t'))
			{
				t += " ";
			}
		}
		//最后把t写入文件
		ofs << t << " " << endl;
	}
	//记得随手关门哟~
	ifs.close();
	ofs.close();
	return 0;
}
  • 14
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无意识程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值