第五次程序设计作业 C++计算器雏形 调用文件输入输出
一.C++计算器作业系列链接
二.本次作业相关
要求:第五次程序设计作业
根据这一次的作业要求,我学习了C++的文件输入输出,调用命令行进行输入的操作,具体代码如下:
main.cpp
#include "calculation.h"
#include "calculator.h"
#include "print.h"
#include <string>
#include <string.h>
#include <queue>
#include <stdlib.h>
#include <iostream>
#include <fstream> //注:这里需要包含头文件<fstream>
using namespace std;
int bitjudge = 0;
int main(int argc,char*argv[])
{
Scan Sc;
Print Put;
Calculation Ca;
//判断是否为文件操作
bool need_file = false;
if(strcmp(argv[1],"-f") == 0)
{
need_file = true;
}
//需要进行文件操作
if(need_file)
{
string getsfile = argv[argc-2]; //输入文件名
string putsfile = argv[argc-1]; //输出文件名
ifstream infile;
ofstream outfile;
//打开文件
infile.open(getsfile.c_str(),ios::in);
outfile.open(putsfile.c_str(),ios::out);
string get_str;
while(!infile.eof()) //未处理到文件尾
{
getline(infile,get_str,'\n'); //读入数据
queue<string> que;
que = Sc.ToStringQueue(get_str);
double result=0;
result = Ca.carryout(que);
outfile << result << endl;
}
//关闭文件
infile.close();
outfile.close();
}
//无须进行文件操作
else
{
queue<string> que;
string str = argv[argc-1];
if(strcmp(argv[1],"-a") == 0) //判断是否有输入'-a'
{
que.push(str);
Put.pout(que); // printf que.
}
while(!que.empty())
que.pop(); // 清空que
que = Sc.ToStringQueue(argv[argc-1]);
if(!que.empty())
cout << Ca.carryout(que) << endl;
else //出错
cout << "error" << endl;
}
return 0;
}
思路做法:
头文件:#include <fstream>
定义一个bool型变量need_file,判断输入的参数是否是-f,是的话置true。
接下来判断need_file是否为真,为假说明无须文件操作,这里说明一下need_file为真的情况。
首先把要求输入的路径和输入的路径分别赋值给两个字符串
getsfile和putsfile,定义一个文件输入流infile和一个文件输出流outfile,用如下语句打开文件:
//打开文件
infile.open(getsfile.c_str(),ios::in);
outfile.open(putsfile.c_str(),ios::out);
注意这里的字符串需要是C风格类型的,若直接是C++风格的字符串
getsfile和putsfile,编译会出错。这里用.c_str转换成C风格的字符串。
接下来就是文件里面的内容进行操作了:
string get_str;
while(!infile.eof()) //未处理到文件尾
{
getline(infile,get_str,'\n'); //读入数据
queue<string> que;
que = Sc.ToStringQueue(get_str);
double result=0;
result = Ca.carryout(que);
outfile << result << endl;
}
用getline函数读入文件中每一行的内容,读入的内容用字符串
get_str存储,再经过计算处理,得到的结果result输入到文件流outfile中。
最后还要注意下文件的关闭:
//关闭文件
infile.close();
outfile.close();
三.实现效果:
命令行:

文件(txt):

注: 输出文件多了一个0,是因为我在输入时多输入了一个回车,文件处理回车所致。
四.思维框架图:

(最后吐槽一下锐捷)
第五次程序设计作业 C++计算器雏形 调用文件输入输出的更多相关文章
- 程序设计第三次作业---C++计算器雏形
Github链接:https://github.com/Wasdns/object-oriented 题目:程序设计第三次作业 程序设计第三次作业附加 我的程序设计第三次作业附加 代码规范 更新时间: ...
- 第四次程序设计作业 C++计算器计算及命令行的使用 前缀表达式方法实现
关键词:前缀中缀后缀表达式 波兰式 命令行 myGithub 一.前言 很有意思的开发和学习经历,从刚刚开始看到作业思考半天到现在的Debug过程,对我来说都或多或少有所提升. 也许这个时候自己挺迷茫 ...
- 程序设计第三次作业--C++计算器初始部分
面向对象程序设计作业3--C++计算器初始部分 Github 链接:https://github.com/luojingzhao/object-oriented/tree/master/calcula ...
- c++ 第五次作业(计算器第三步)
第五次作业 (计算器第三步) 项目源文件地址:calculator 本次作业改进情况 加入多种读入选择 正常输出答案 -a 选项,输出表达式以及值 -f 选项,从指定文件读入,并把答案输出到指定文件 ...
- 17秋 SDN课程 第五次上机作业
17秋 SDN课程 第五次上机作业 Project:https://github.com/Wasdns/new_balance Slide is available at https://github ...
- Python 迭代器&生成器,装饰器,递归,算法基础:二分查找、二维数组转换,正则表达式,作业:计算器开发
本节大纲 迭代器&生成器 装饰器 基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ...
- 《团队作业第三、第四周》五阿哥团队作业--Scrum 冲刺阶段--Day1--领航
<团队作业第三.第四周>五阿哥团队作业--Scrum 冲刺阶段--Day1--领航 各个成员在 Alpha 阶段认领的任务 在团队合作时任务也会动态分配,最终以实际为主,上述具有参考价值. ...
- 2019 SDN第五次上机作业
2019 SDN第五次上机作业 作业链接 1.浏览RYU官网学习RYU控制器的安装和RYU开发入门教程,提交对于教程代 码的理解,包括但不限于: 安装RYU控制器并测试 安装教程 安装过程及遇到各种问 ...
- Android简易实战教程--第十五话《在外部存储中读写文件》
第七话里面介绍了在内部存储读写文件 点击打开链接. 这样有一个比较打的问题,假设系统内存不够用,杀本应用无法执行,或者本应用被用户卸载重新安装后.以前保存的用户名和密码都不会得到回显.所以,有必要注意 ...
随机推荐
- react-native run-android error: unknown host service
D:\rnworkspace\Hello>react-native run-android JS server already running.Running D:\Android\sdk/pl ...
- Spring和Spring MVC包扫描
在Spring整体框架的核心概念中,容器是核心思想,就是用来管理Bean的整个生命周期的,而在一个项目中,容器不一定只有一个,Spring中可以包括多个容器,而且容器有上下层关系,目前最常见的一种场景 ...
- sap gui 使用方法, sap logon
1:打断点:在程序保存并激活之后,可以打内部或外部断点. 如图示. 2: display 展示程序,不能修改. 3: 查看创建的类的结构,使用more>display object list ...
- libsvm使用
先挖个坑,有空重写svm_scale, svm_train, svm_predict几个代码,给的实在写的不敢恭维 package org.ml.svm; import java.io.File; i ...
- Chapter 7 Integrity(完整性), Views(视图), Security(安全性), and Catalogs(目录)
from Database Design to Physical Form CREATE TABLE integrity constraints (完整性约束) CREATE VIEW Securit ...
- Summary: Depth-first Search(DFS)
There are generally two methods to write DFS algorithm, one is using recursion, another one is using ...
- #C++初学记录(深度搜索#递归)
深度搜索 走地图的题目是深度搜索里比较容易理解的题目,更深层次的是全排列和七皇后等经典题目,更加难以理解,代码比较抽象. 题目:红与黑 蒜厂有一间长方形的房子,地上铺了红色.黑色两种颜色的正方形瓷砖. ...
- STA分析(二) multi_cycle and false
multicycle path:当FF之间的组合逻辑path propagate delay大于一个时钟cycle时,这条combinational path能被称为multicycle path. ...
- kafka集群监控工具之三--kafka Offset Monitor
1.介绍 一般情况下,功能简单的kafka项目 使用运维命令+kafka Offset Monitor 就足够用了. 2.使用2.1 部署 github下载jar包 KafkaOffsetMonit ...
- 能让程序做的事情坚决不用人来做——批量修复markdownlint MD034警告
欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...