当前位置: 首页 > news >正文

实验四【文件操作】

物联1251

xcjie

题目一:数据持久化——增加与保存1

任务:使⽤ fprintf 函数将数组内容持久化存储到名为 farms.txt 的⽂本⽂件中。
⽂件操作重点:使⽤ “w” 模式打开⽂件,掌握 fprintf 的格式化写⼊。
要求:每⾏存储⼀个产地的信息,字段间⽤空格分隔。

#include <stdio.h> #include <stdlib.h> typedef struct{ int id; char name[50]; int yield; }OrangeFarm; int main(){ OrangeFarm new_farm; FILE*fp; printf("---廉江红橙产地数据追加---\n"); printf("请输入新增产地信息(格式:ID 名称 产量):\n"); if(scanf("%d%s%d",&new_farm.id,new_farm.name,&new_farm.yield)!=3){ printf("输入格式错误。\n"); return 1; } fp=fopen("farms.txt","a"); if(fp==NULL){ printf("错误:无法打开文件进行追加!\n"); return 1; } fprintf(fp,"%d%s%d\n",new_farm.id,new_farm.name,new_farm.yield); fclose(fp); printf("\n新纪录已成功追加至farms.txt末尾。\n"); return 0; }

题⽬ 2:数据过滤——读取与删除
【任务】:先将 farms.txt 中的所有数据加载到结构体数组中。⽤户输⼊⼀个要删除的“产地ID”,程序在数组中剔除该条⽬后,将剩余数据重新覆盖写⼊ farms.txt 。
⽂件操作重点:使⽤ “r” 模式读取, feof() 或 fscanf() != EOF 判断⽂件结尾。
删除逻辑:在内存(数组)中完成删除,再通过重新打开⽂件并写⼊来实现“物理删除”。

#include <stdio.h> #include <string.h> #include <stdlib.h> typedef struct{ int id; char name[50]; int yield; }OrangeFarm; int main(){ OrangeFarm farms[100]; int count=0; int deleted; char confirm; FILE*fp; fp=fopen("farms.txt","r"); if(fp==NULL){ printf("错误:无法打开farms.txt,请确保文件已存在。\n"); return 1; } while(fscanf(fp,"%d%s%d",&farms[count].id,farms[count].name,&farms[count].yield)==3){ count++; } fclose(fp); if(count==0){ printf("数据库为空,无数据可删除。\n"); return 0; } printf("\n--- 当前廉江红橙产地列表 ---\n"); for (int i = 0; i < count; i++) { printf("[%d] %-12s", farms[i].id, farms[i].name); if ((i + 1) % 3 == 0) { printf("\n"); } } printf("\n---------------------------\n"); printf("请输?要删除的产地 ID: "); scanf("%d", &deleted); int targetIndex = -1; for (int i = 0; i < count; i++) { if (farms[i].id == deleted) { targetIndex = i; break; } } if (targetIndex == -1) { printf("错误:未找到 ID 为 %d 的记录。\n", deleted); return 0; } printf("\n拟删除记录详情:\n"); printf("ID: %d | 名称: %s | 产量: %d 吨\n", farms[targetIndex].id, farms[targetIndex].name, farms[targetIndex].yield); printf("警告:此操作不可撤回!确定删除吗?(y/n): "); getchar(); scanf("%c", &confirm); if (confirm != 'y' && confirm != 'Y') { printf("操作已安全取消。\n"); return 0; } for (int i = targetIndex; i < count - 1; i++) { farms[i] = farms[i + 1]; } count--; fp = fopen("farms.txt", "w"); if (fp == NULL) { printf("系统错误:?法更新?件数据。\n"); return 1; } for (int i = 0; i < count; i++) { fprintf(fp, "%d %s %d\n", farms[i].id, farms[i].name, farms[i].yield); } fclose(fp); printf("成功:ID 为 %d 的记录已从系统中彻底移除。\n", deleted); return 0; }

题⽬ 3:精准更新——加载与修改
【任务】:实现交互式修改。

程序打开⽂件并加载所有 ID 供⽤户预览。
⽤户输⼊⽬标 ID。
程序提⽰⽤户选择修改项(1.修改名称 2.修改产量)。
⽤户输⼊新值后,程序更新数组并同步回⽂件。
⽂件操作重点:掌握“内存加载 -> 修改 -> 重新回写”的完整链路。
要求:利⽤ switch-case 结构处理⽤户的修改选择。

#include <stdio.h> #include <string.h> #include <stdlib.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { OrangeFarm farms[100]; int count = 0; int targetId, choice; FILE *fp; fp = fopen("farms.txt", "r"); if (fp == NULL) { printf("错误:非法打开 farms.txt,请确保文件已存在。\n"); return 1; } while (fscanf(fp, "%d %s %d", &farms[count].id, farms[count].name, &farms[count].yield) == 3) { count++; } fclose(fp); if (count == 0) { printf("数据库为空,请先添加数据。\n"); return 0; } printf("--- 当前系统内的产地 ID 列表 ---\n"); for (int i = 0; i < count; i++) { printf("[%d] %-12s", farms[i].id, farms[i].name); if ((i + 1) % 3 == 0) { printf("\n"); } } printf("\n-------------------------------\n"); printf("请输入您想要修改的产地 ID: "); scanf("%d", &targetId); int index = -1; for (int i = 0; i < count; i++) { if (farms[i].id == targetId) { index = i; break; } } if (index == -1) { printf("未找到 ID 为 %d 的记录。\n", targetId); return 0; } printf("\n已锁定产地: %s (产量: %d 吨)\n", farms[index].name, farms[index].yield); printf("1. 修改产地名称\n"); printf("2. 修改预计产量\n"); printf("3. 取消修改\n"); printf("请选择操作 (1-3): "); scanf("%d", &choice); switch (choice) { case 1: printf("请输入新的名称: "); scanf("%s", farms[index].name); break; case 2: printf("请输入新的产量 (吨): "); scanf("%d", &farms[index].yield); break; case 3: printf("操作已取消。\n"); return 0; default: printf("非法输入,操作终止。\n"); return 0; } fp = fopen("farms.txt", "w"); if (fp == NULL) { printf("回写文件失败!\n"); return 1; } for (int i = 0; i < count; i++) { fprintf(fp, "%d %s %d\n", farms[i].id, farms[i].name, farms[i].yield); } fclose(fp); printf("ID 为 %d 的记录已成功更新。\n", targetId); return 0; }

题⽬ 4:条件检索——读取与查询

【任务】:编写⼀个查询⼯具。⽤户输⼊⼀个“产量阈值”,程序打开⽂件读取数据,通过遍历结构体数组,筛选并打印出所有产量⼤于该阈值的产地信息。
⽂件操作重点:使⽤循环配合 fscanf 逐⾏解析数据。
逻辑重点:考查结构体成员的访问与逻辑判断表达式。

#include <stdio.h> #include <stdlib.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { FILE *fp; OrangeFarm temp; int threshold; int foundCount = 0; fp = fopen("farms.txt", "r"); if (fp == NULL) { printf("错误:无法打开数据文件 farms.txt,请确保文件已存在。\n"); return 1; } printf("----------- 廉江红橙产量筛选系统 -----------\n"); printf("请输入产量阈值(吨):"); if (scanf("%d", &threshold) != 1) { printf("输入无效。\n"); fclose(fp); return 1; } printf("\n正在查询产量大于 %d 吨的产地...\n", threshold); printf("-------------------------------------------\n"); printf("%-10s %-20s %-10s\n", "ID", "产地名称", "预计产量(吨)"); printf("-------------------------------------------\n"); while (fscanf(fp, "%d %s %d", &temp.id, temp.name, &temp.yield) == 3) { if (temp.yield > threshold) { printf("%-10d %-20s %-10d\n", temp.id, temp.name, temp.yield); foundCount++; } } if (foundCount == 0) { printf("未找到产量超过 %d 吨的记录。\n", threshold); } else { printf("-------------------------------------------\n"); printf("查询完毕,共找到 %d 条记录。\n", foundCount); } fclose(fp); return 0; }
http://www.hn-smt.com/news/162358/

相关文章:

  • 智能数字资产管理平台的跨链智能合约架构
  • WebSocket长连接+TensorRT流式输出:实时交互新范式
  • jlink驱动Windows安装指南:从下载到识别完整流程
  • XADC IP核采集噪声处理:系统学习
  • 剖析关键!提示工程架构师把控提示系统技术生态培育的关键要素
  • AI应用开发核心模块五——MCP:AI的“对外沟通桥梁”
  • Driver Store Explorer核心要点:驱动版本管理优化
  • 一文搞懂TensorRT核心机制:层融合、内存复用与内核实例化
  • STM32串口DMA内存管理策略系统学习
  • Windows下STM32CubeMX打不开的超详细版解决方案
  • 构建专属AI客服系统:TensorRT加速下的响应速度革命
  • STM32CubeMX安装教程:驱动安装与常见问题解析
  • 开源模型商用合规吗?搭配TensorRT后的法律风险提示
  • JLink仿真器在IAR中调试配置完整示例
  • IAR软件配合STM32实现SWD下载:操作详解
  • 不只是快:TensorRT镜像带来的稳定性与可扩展性提升
  • AI智能体学习新范式:从权重更新到Token空间学习,程序员必收藏!
  • 运动健身计划定制:体能评估结果由TensorRT分析驱动
  • Proteus8.16下载安装教程:从零开始构建单片机仿真平台
  • 数据清洗自动化:脏数据识别模型通过TensorRT批量处理
  • S32DS使用系统学习:集成FreeRTOS的完整示例分析
  • 新手入门必看:Proteus安装避坑指南
  • 揭秘NVIDIA官方推荐的模型部署方案:TensorRT到底强在哪?
  • Keil uVision5嵌入式C开发:外设寄存器映射通俗解释
  • NX系统中GPIO抽象层开发完整示例
  • Seurat V5 结构树和基础整合pipeline
  • CCS20多文件编译优化协调策略一文说清
  • STLink引脚图详解:STM32调试接口全面讲解
  • TensorRT技术揭秘:如何让HuggingFace模型在生产环境飞起来?
  • [uniapp][swtich开关]阻止切换状态(类似阻止事件冒泡)