C语言图书管理系统控制台程序

程序示例精选
C语言图书管理系统控制台程序
如需安装运行环境或远程调试,见文章底部个人QQ名片,由专业技术人员远程协助!

前言

这篇博客针对《C语言图书管理系统控制台程序》编写代码,代码整洁,规则,易读。 学习与应用推荐首选。


文章目录

一、所需工具软件
二、使用步骤
       1. 主要代码
       2. 运行结果
三、在线协助

一、所需工具软件

       1. VS2022
       2. C++

二、使用步骤

代码如下(示例):
typedef struct
{
    char no[20];     // 书号
    char name[20];    // 书名
    char author[20];  // 作者
    float price;      // 价格 
    int count;      //数量 

}book;

book bk[MAXNUM];

int cnt = 0; //图书总数量 

void readFile() //读文件 
{
    FILE* fo;
    fo = fopen("bookdata.txt", "r");
    fscanf(fo, "%d", &cnt);
    int i;
    for (i = 1; i <= cnt; i++)
    {
        fscanf(fo, "%s", bk[i].no);
        fscanf(fo, "%s", bk[i].name);
        fscanf(fo, "%s", bk[i].author);
        fscanf(fo, "%f", &bk[i].price);
        fscanf(fo, "%d", &bk[i].count);

    }
    fclose(fo);
}

void saveFile() //写文件 
{
    FILE* fp;
    fp = fopen("bookdata.txt", "w");
    int i;
    fprintf(fp, "%d\n", cnt);
    for (i = 1; i <= cnt; i++)
    {
        fprintf(fp, "%5s", bk[i].no);
        fprintf(fp, "%10s", bk[i].name);
        fprintf(fp, "%13s", bk[i].author);
        fprintf(fp, "%13f", bk[i].price);
        fprintf(fp, "%13d\n", bk[i].count);
    }
    fclose(fp);
}

void swap(char* src, char* des) //字符串交换
{
    char t[100];
    strcpy(t, src);
    strcpy(src, des);
    strcpy(des, t);
}

void addbook() //新增图书
{
    system("cls");

    char a[20];
    system("cls");
    printf("  ********** 增加图书 **********\n");
    cnt++; //图书的数量+1 

    printf("请输入图书书号: ");
    scanf("%s", a);
    if (search_no(a) != 0) {

        printf("该书已存在,您可以返回主菜单选择修改信息\n");
        cnt--;
        return;
    }
    swap(a, bk[cnt].no);

    printf("请输入图书书名: ");
    scanf("%s", bk[cnt].name);

    printf("请输入图书作者: ");
    scanf("%s", bk[cnt].author);

    printf("请输入图书价格: ");
    scanf("%f", &bk[cnt].price);

    printf("请输入图书数量: ");
    scanf("%d", &bk[cnt].count);

    printf("新增成功!");
}

void sort_menu() // 排序图书菜单 
{
    system("cls");
    printf("请选择排序方式:\n");
    printf("1 书号  ");
    printf("2 书名  ");
    printf("0 退出\n");
    printf("请选择:");
}

void del_menu() //删除图书菜单 
{
    system("cls");
    printf(" ********** 删除图书 **********\n");
    printf(" 请选择删除方式:\n");
    printf(" 1 书号  ");
    printf(" 2 书名  ");
    printf(" 0 退出\n");
    printf("请选择:");
}

void search_menu() // 查找图书菜单 
{
    system("cls");
    printf("  ********** 查找图书 **********\n");
    printf(" 请选择查找方式:\n");
    printf(" 1 书号  ");
    printf(" 2 书名  ");
    printf(" 3 作者  ");
    printf(" 0 退出\n");
    printf("请选择:");
}

void change_menu() //修改图书菜单 
{
    system("cls");
    printf(" ********** 修改图书 **********\n");
    printf(" 请选择修改方式:\n");
    printf(" 1 书号  ");
    printf(" 2 书名  ");
    printf(" 0 退出\n");
    printf(" 请选择:");

}

void print_menu()  // 输出菜单 
{
    system("cls");
    printf("\n********** 图书管理系统 **********\n\n");
    printf("\t1 增加图书\n");
    printf("\t2 修改图书\n");
    printf("\t3 删除图书\n");
    printf("\t4 查找图书\n");
    printf("\t5 图书排序\n");
    printf("\t6 图书显示\n");
    printf("\t7 图书销售\n");
    printf("\t0 退出系统\n\n");
    printf("\t请选择要执行的操作: ");
}

void print_head()  // 打印说明文字 
{
    char id[5] = "序号";
    char no[5] = "书号";
    char name[5] = "书名";
    char author[9] = "作者";
    char price[11] = "价格";
    char count[11] = "数量";
    printf("% 5s", id);
    printf("%10s", no);
    printf("%13s", name);
    printf("%13s", author);
    printf("%13s", price);
    printf("%13s", count);
    printf("\n");
}

void output(int i)  //输出 cnt 为 i 的图书信息 
{
    printf("%10s", bk[i].no);
    printf("%13s", bk[i].name);
    printf("%13s", bk[i].author);
    printf("%15.2f", bk[i].price);
    printf("%15d\n", bk[i].count);
}



int main()
{
    int i, j;
    while (1)
    {
        readFile();
        print_menu();
        int n;
        scanf("%d", &n);
        printf("\n");
        if (n == 0) {
            printf("\t谢谢您的使用!");
            break;
        }
        switch (n)
        {
        case 1: //增加图书 
            addbook();
            break;

        case 2://修改图书 
            change_menu();
            int p;
            scanf("%d", &p);
            if (p == 0)
                break;
            switch (p)
            {
            case 1:
                printf(" 请输入要修改书的书号:");
                char no[20];
                scanf("%s", no);
                j = search_no(no);
                if (j == 0)
                    printf(" 未查找到该书!\n\t");
                else {
                    change(j);
                    printf("修改成功!");
                }

                break;
            case 2:
                printf(" 请输入要修改书的书名:");
                char name[20];
                scanf("%s", name);
                i = search_name(name);
                if (i == 0)
                    printf(" 未查找到该书!\n\t");
                else {
                    change(i);
                    printf("修改成功!");
                }

                break;
            default:
                printf(" 输入错误!\n\t");
            }
            break;

        case 3://删除图书 
            del_menu();
            int p1;
            scanf("%d", &p1);
            if (p1 == 0)
                break;
            switch (p1)
            {
            case 1:
                printf("请输入要删除书的书号:");
                char num[20];
                scanf("%s", num);
                j = search_no(num);
                if (j == 0)
                    printf("未查找到该书!\n");
                else {
                    del(j);
                    printf("删除成功!");
                }

                break;
            case 2:
                printf("请输入要删除书的书名:");
                char name[20];
                scanf("%s", name);
                i = search_name(name);
                if (i == 0)
                    printf("未查找到该书!");
                else {
                    del(i);
                    printf("删除成功!");
                }

                break;
            default:
                printf("输入错误!\n");
            }
            break;

        

        default:
            printf("输入有误,请重新选择:\n\n");
        }
        saveFile();//保存 
        pause();
    }
    system("pause");
    return 0;
}




运行结果

三、在线协助:

如需安装运行环境或远程调试,见文章底部个人 QQ 名片,由专业技术人员远程协助!

1)远程安装运行环境,代码调试
2)Visual Studio, Qt, C++, Python编程语言入门指导
3)界面美化
4)软件制作
5)云服务器申请
6)网站制作

当前文章连接:https://blog.csdn.net/alicema1111/article/details/132666851
个人博客主页:https://blog.csdn.net/alicema1111?type=blog
博主所有文章点这里:https://blog.csdn.net/alicema1111?type=blog

博主推荐:
Python人脸识别考勤打卡系统:
https://blog.csdn.net/alicema1111/article/details/133434445
Python果树水果识别:https://blog.csdn.net/alicema1111/article/details/130862842
Python+Yolov8+Deepsort入口人流量统计:https://blog.csdn.net/alicema1111/article/details/130454430
Python+Qt人脸识别门禁管理系统:https://blog.csdn.net/alicema1111/article/details/130353433
Python+Qt指纹录入识别考勤系统:https://blog.csdn.net/alicema1111/article/details/129338432
Python Yolov5火焰烟雾识别源码分享:https://blog.csdn.net/alicema1111/article/details/128420453
Python+Yolov8路面桥梁墙体裂缝识别:https://blog.csdn.net/alicema1111/article/details/133434445
Python+Yolov5道路障碍物识别:https://blog.csdn.net/alicema1111/article/details/129589741
Python+Yolov5跌倒检测 摔倒检测 人物目标行为 人体特征识别:https://blog.csdn.net/alicema1111/article/details/129272048

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/758297.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW程序员应该怎么提高自己的工作能力?

作为一名LabVIEW程序员&#xff0c;提升工作能力可以从以下几个方面入手&#xff1a; 1. 深入理解LabVIEW基础 掌握LabVIEW编程语言&#xff1a;熟悉LabVIEW的图形化编程方式&#xff0c;理解其数据流编程模型。熟悉常用的VI&#xff08;虚拟仪器&#xff09;和函数&#xff1…

Flink 从入门到放弃

0 写在前面 程序员闯荡江湖的一生都在与数据打交道&#xff0c;初入江湖时基于 MySQL 的 CRUD&#xff0c;渐入佳境后利用 Redis 实现查询加速及分布式控制&#xff0c;本质上都是数据处理&#xff1b;无论主动/被动&#xff0c;都在利用数据来达成业务/技术目的。自然而然的&a…

The this Pointer (this 指针) and An Array of Objects (对象数组)

The this Pointer [this 指针] and An Array of Objects [对象数组] 1. The this Pointer (this 指针)2. An Array of Objects (对象数组)References 1. The this Pointer (this 指针) class Stock { private:double total_val_;... public:double Total() const { return tot…

详细解释Redis的SET NX命令

详细解释Redis的SET NX命令 SET NX 命令是 Redis 中用于实现分布式锁的一个重要命令。它的语法和用法如下&#xff1a; SET key value NX [EX seconds | PX milliseconds]参数解释 key&#xff1a;要设置的键名。value&#xff1a;要设置的键值&#xff0c;通常用一个唯一标…

什么是无头浏览器?

简而言之&#xff0c;无头浏览器是没有图形用户界面 &#xff08;GUI&#xff09; 的 Web 浏览器。GUI 包括用户与之交互的数字元素&#xff0c;例如按钮、图标和窗口。但是&#xff0c;关于无头浏览器&#xff0c;您需要了解的还有很多。 在本文中&#xff0c;您将了解什么是…

2007-2022年 省级-绿色农业合作社数量相关数据整理

绿色农业合作社作为一种推动农业可持续发展的组织形式&#xff0c;对于促进环境保护、提高农产品质量和增加农民收入等方面具有重要作用。以下是对省级绿色农业合作社数量相关数据的介绍&#xff1a; 数据简介 定义&#xff1a;绿色农业合作社是由农民、农业专家、企业家等组…

关于Redisson分布式锁的用法

关于Redisson分布式锁的用法 Redisson是一个基于Redis的Java分布式对象和服务框架&#xff0c;它提供了多种分布式锁的实现&#xff0c;包括可重入锁、公平锁、读写锁等。Redisson实现分布式锁的核心原理主要依赖于Redis的数据结构和Redisson框架提供的高级功能。以下详细讲解…

基于RK3588的GMSL、FPDLink 、VByone及MIPI等多种摄像模组,适用于车载、机器人工业图像识别领域

机器人&工业摄像头 针对机器人视觉与工业检测视觉&#xff0c;信迈自主研发和生产GMSL、FPDLink 、VByone及MIPI等多种摄像模组&#xff0c;并为不同应用场景提供多种视场角度和镜头。拥有资深的图像算法和图像ISP专家团队&#xff0c;能够在软件驱动层开发、ISP算法、FPG…

sql-语句

文章目录 SQL语句的学习sql是什么sql的内置命令sql的种类sql mode库&#xff0c;表属性介绍&#xff1a;字符集&#xff0c;存储引擎列的数据类型&#xff1a;数字&#xff0c;字符串&#xff0c;时间列的约束DDL: 数据定义语言库表 Online DDL(ALGORITHM) *DML :数据操纵语言资…

算法:链表

目录 链表的技巧和操作总结 常用技巧&#xff1a; 链表中的常用操作 题目一&#xff1a;反转一个单链表 题目二&#xff1a;链表的中间结点 题目三&#xff1a;返回倒数第k个结点 题目四&#xff1a;合并两个有序链表 题目五&#xff1a;移除链表元素 题目六&#xff…

033基于SSM+Jsp的多用户博客个人网站

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…

GPIO和PIN

文章目录 1 GPIO和Pin1.1 GPIO和Pin基础概念1.2 GPIO输入模式1.3 GPIO输出模式1.4 GPIO的HAL库1.4.1 一些HAL库表示1.4.2 HAL库常用GPIO函数1.4.3 GPIO点亮led灯程序例子 1 GPIO和Pin 1.1 GPIO和Pin基础概念 ​ 单片机有很多的引脚&#xff0c;为了操控每一个引脚&#xff0c…

JVM原理(四):JVM垃圾收集算法与分代收集理论

从如何判定消亡的角度出发&#xff0c;垃圾收集算法可以划分为“引用计数式垃圾收集”和“追踪式垃圾收集”两大类。 本文主要介绍的是追踪式垃圾收集。 1. 分代收集理论 当代垃圾收集器大多遵循“分代收集”的理论进行设计&#xff0c;它建立在两个假说之上&#xff1a; 弱分…

Git企业开发---初识Git

顾得泉&#xff1a;个人主页 个人专栏&#xff1a;《Linux操作系统》 《C从入门到精通》 《LeedCode刷题》 键盘敲烂&#xff0c;年薪百万&#xff01; 引言 不知道大家有没有经历这种困惑&#xff0c;当我们要去交某文档时&#xff0c;总是要进行修改&#xff0c;修改后再交…

【知识学习】Unity3D中Shader Graph的概念及使用方法示例

Unity3D中的Shader Graph是一个强大的可视化Shader编辑工具&#xff0c;它允许用户通过拖拽和连接节点的方式来创建Shader&#xff0c;而不是通过传统的编写代码的方式。Shader Graph使得Shader的创建过程更加直观和易于理解&#xff0c;特别是对于那些不熟悉Shader语言编程的美…

19.《C语言》——【如何理解static和extern?】

&#x1f387;开场语 亲爱的读者&#xff0c;大家好&#xff01;我是一名正在学习编程的高校生。在这个博客里&#xff0c;我将和大家一起探讨编程技巧、分享实用工具&#xff0c;并交流学习心得。希望通过我的博客&#xff0c;你能学到有用的知识&#xff0c;提高自己的技能&a…

MDA管理层讨论与分析内容信息披露情感分析数据(2010-2022年)

数据简介&#xff1a;MD&A通常是指管理层讨论与分析&#xff08;Management Discussion & Analysis&#xff09;&#xff0c;是上市公司年报中一个重要的部分&#xff0c;主要包含公司经营业绩的讨论&#xff0c;以及未来前景的预测等。MD&A可以帮助投资者更好地理…

leetcode 第133场双周赛 100333.统计逆序对的数目【计数dp/滚动数组/前缀和优化】

分析&#xff1a; 先考虑如下问题。 求长度为n&#xff0c;逆序对为m的排列数量。 可以考虑dp&#xff0c;dp[i][j]定义为长度为i&#xff0c;逆序对为j的排列数量。 dp[1][0] 1; //枚举排列长度&#xff0c;或者认为枚举当前需要插到长度为i-1的排列中的数字 for(int i 1…

笔记本电脑安装CentOS

正文共&#xff1a;1234 字 24 图&#xff0c;预估阅读时间&#xff1a;2 分钟 前面我们对VPP进行了多次介绍&#xff08;羡慕&#xff01;大佬的VPP能达到180G性能&#xff0c;而我的却只有13.5G&#xff09;&#xff0c;可以发现他的很多优点&#xff0c;但是我们也可以发现它…

socket编程常见操作

1、连接的建立 分为两种&#xff1a;服务端处理接收客户端的连接&#xff1b;服务端作为客户端连接第三方服务 //作为服务端 int listenfd socket(AF_INET, SOCK_STREAM, 0); bind(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr))) listen(listenfd, 10); //…