字典查找对应输入的字符

news2024/11/25 16:31:56
一、将文件放入到数据库

#include<stdio.h>
#include<sqlite3.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
#include <unistd.h>
int main(int agrc,char *agrv[])
{
    FILE *fp;
    fp= fopen("./dict.txt","r");
    if(fp == NULL)
    {
        perror("fopen fail");
        return -1;
    }
    char buf[1024] = {0};
    sqlite3 *pdb;
    int ret = sqlite3_open("./stu.db",&pdb);
    if(ret != SQLITE_OK)
    {
        fprintf(stderr,"sqlite3_open fail : %s\n",sqlite3_errmsg(pdb));
        return -1;
    }
    char *sql = "create table if not exists class6(id INTEGER PRIMARY KEY AUTOINCREMENT,word TEXT,meaning TEXT);";
    ret = sqlite3_exec(pdb,sql,NULL,NULL,NULL);
    if(ret != SQLITE_OK)
    {
        fprintf(stderr,"sqlite3_open1 fail: %s\n",sqlite3_errmsg(pdb));
        sqlite3_close(pdb);
        return -1;
    }
    while(!feof(fp))
    {
        char *buf1[2];
        char buf2[1024] = {0};
        memset(buf,0,sizeof(buf));
        fgets(buf,sizeof(buf),fp);
        buf1[0] = strtok(buf," ");
        buf1[1]  = strtok(NULL,"\r");
        sprintf(buf2,"insert into class6 values(NULL,\"%s\",\"%s\")",buf1[0],buf1[1]);
        sql = buf2;
        ret = sqlite3_exec(pdb,sql,NULL,NULL,NULL);
        if(ret !=SQLITE_OK)
        {
            fprintf(stderr,"sqlite3_open2 fail : %s\n",sqlite3_errmsg(pdb));
            sqlite3_close(pdb);
            return -1;
        }

    }
sqlite3_close(pdb);
fclose(fp);
return 0;
}
二、查找数据库
#include<stdio.h>
#include<sqlite3.h>
#include<string.h>
char buf[100] = {0};
int callback(void *arg,int column_cnt,char **column_value,char **column_name)
{
    if(strcmp(column_value[0],buf) == 0)
    {
        printf("meaning = %s\n",column_value[1]);
    }
    return 0;
}
int main(int agrc,char *agrv[])
{
    sqlite3 *pdb;:
    int ret = sqlite3_open("./stu.db",&pdb);
    if(ret != SQLITE_OK)
    {
        fprintf(stderr,"sqlite3_open fail : %s\n",sqlite3_errmsg(pdb));
        return -1;
    }
    char *sql = "select word,meaning from class6;";
    fgets(buf,sizeof(buf),stdin);
    buf[strlen(buf) + 1] = '\0';
    ret = sqlite3_exec(pdb,sql,callback,NULL,NULL);
    if(ret != SQLITE_OK)
    {
        fprintf(stderr,"sqlite3_open1 fail: %s\n",sqlite3_errmsg(pdb));
        sqlite3_close(pdb);
        return -1;
   
    }
    sqlite3_close(pdb);
    return 0;
}
三、用到的函数
3.1、fgets()

fgets函数函数用来从stream所指文件中读入buf[size-1]个字符放入buf为起始地址的空间内;如果在未读满bufsize-1个字符之时,已读到一个换行符或一个EOF(文件结束标志),则结束本次读操作,读入的字符串中最后包含读到的换行符。并在结尾处加上“\0”组成一个字符串,存入“字符串指针”中。若函数调用成功,则返回存放字符串的首地址;若读到文件结尾处或调用失败时,则返回字符常量 NULL。或者已经读到size -1,这个时候注意,我们如果要读文件,读这个数据的时候,若已经放满了,则没有\0,会造出读的时候指针越界,因此在只读[sizeof - 1]。当他把一行读完,文件流指针,会自动指向下一个。

3.2、feof()

int feof(FILE *stream);

功能

检测流上的文件结束符

返回值

如果文件结束,则返回非0值,否则返回0,文件结束符只能被clearerr()清除

3.3、ferror()

int ferror(FILE *stream);

ferror(src)检查文件到底是否出错,注意,发生读的错误

文件流里面有flag 表示文件是否从错误

 四、查找过程中出现的错误

1、strlen()之后,得到的是有效字符的个数,那么如果我们想对\n去掉的话,那么必须是长度-1,因为我们数组是从0开始的。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

详细介绍校园网络拓扑结构设计图

目录 需求分析 网络架构设计 拓扑图设计 安全策略 出口设计 总结 校园网络拓扑结构设计是一种对学校内计算机、网络设备和软件进行集成应用的系统化设计&#xff0c;旨在为师生提供一个高效、稳定、安全的网络平台&#xff0c;以支持教学、科研和管理的信息化需求。一个优…

RKNPU2从入门到实践 ---- 【8】借助 RKNN Toolkit lite2 在RK3588开发板上部署RKNN模型

前言 作者使用的平台为Ubuntu20.04虚拟系统&#xff0c;开发板为瑞芯微RK3588&#xff0c;开发板上的系统为Ubuntu22.04系统。 一、任务 完成RKNN模型的部署&#xff0c;RKNN模型的部署是将RKNN模型放到开发板上&#xff0c;应用程序可以加载RKNN模型&#xff0c;从而在嵌入式…

进阶SpringBoot之 Shiro(1)快速开始

Shiro 是一个 Java 的安全&#xff08;权限&#xff09;框架&#xff0c;它可以在 JavaSE、JavaEE 环境下使用 Shiro 可以实现认证、授权、加密、会话管理、Web 集成、缓存等 Shiro 官网 Shiro 中文文档 GitHub 下载 Shiro 下载源码&#xff0c;samples -> quickstart …

Linux-全网备份实战案例rsync邮件发送

项目准备 服务端&#xff1a;backup&#xff1a;172.16.1.41 客户端1&#xff1a;nfs:172.16.1.31 客户端2&#xff1a; web01:172.16.1.7 1.1 服务端backup-rsync配置文件 [rootbackup ~]# cat /etc/rsyncd.conf #created by linux 2024-8-29 ###########rsyncd.conf star…

进程和线程(操作系统八股文part2)

一个操作系统的进程和线程部分的笔记&#xff0c;大部分来源于&#xff1a;小林coding和Javaguide&#xff0c;以及操作系统黑书。 进程和线程 什么是进程 运行中的程序叫进程**&#xff08;Process&#xff09;**。 进程是资源分配的最小单位&#xff0c;线程是执行的最小…

【逐行注释】MATLAB下的UKF(无迹卡尔曼滤波),带丰富的中文注释,可直接复制到MATLAB上运行,无需下载

文章目录 程序组成部分完整代码运行结果主要模块解读:运动模型绘图部分误差统计特性输出程序组成部分 由模型初始化、运动模型、UKF主体部分、绘图代码和输出部分组成: 完整代码 将下列代码复制粘贴到MATLAB里面,即可运行: % 三维状态量的UKF例程 % 作者联系方式:微信…

学苑教育杂志社学苑教育编辑部学苑教育杂志2024年第23期目录

专题研究 “三全六为”教育教学理念的实践运用 果艳青; 4-6 教育管理 班主任班级管理工作中进行小组合作的优化策略 肖堂花; 7-9 课堂教学 以“创新”为支点&#xff0c;构建小学数学活力课堂 马绪如; 10-12 案例教学法在初中道德与法治教学中的应用 何瑞娟; 1…

js实现队列

目录 一、什么是JavaScript队列数据结构二、创建一个JavaScript队列数据结构三、封装队列方法①向队列添加元素②检查队列是否为空③获取队列的长度④从队列移除元素⑤查看队列头元素⑥清空队列⑦创建toString方法 四、使用Queue类 一、什么是JavaScript队列数据结构 在上一篇…

【解析几何笔记】11.向量的外积运算

11. 向量的外积运算 【注】也可以这么计算 11.1 向量的多重乘积 【命题】任意三个向量&#xff0c; α , β , γ \pmb{\alpha},\pmb{\beta},\pmb{\gamma} α,β,γ&#xff0c; ( α β ) γ ( α ⋅ γ ) β − ( β ⋅ γ ) α (\pmb{\alpha}\times\pmb{\beta})\times\p…

Java 7.4 - 分布式锁

什么是分布式锁&#xff1f; 对于单机多线程&#xff0c;我们使用 ReentrantLock 这类本地锁来控制多个线程对本地共享资源的访问&#xff1b;而对于分布式系统&#xff0c;我们使用 分布式锁 来控制多个服务对共享资源的访问。 分布式锁基本要求&#xff1a; 1、互斥 2、高…

【自由能系列(中级)】自由能与变分自由能——从状态到配置的效益最大化

自由能与变分自由能——从状态到配置的效益最大化 关键词提炼 #自由能 #变分自由能 #状态函数 #配置函数 #效益最大化 #物理系统 #优化问题 第一节&#xff1a;自由能与变分自由能的类比与核心概念 1.1 自由能与变分自由能的类比 自由能和变分自由能可以被视为物理系统的“…

最火视频素材去哪里找?热门的视频素材网站库分享给你

你是否正在寻找那些能够让你的视频作品一鸣惊人的优质素材&#xff1f;如果你还在为如何让视频内容更加出彩而苦恼&#xff0c;那么今天你就来对地方了&#xff01;我将为你介绍几个非常实用且资源丰富的视频素材网站&#xff0c;让你的作品在众多视频中脱颖而出&#xff0c;成…

element的el-steps里的数据处理用switch 循环,处理的数据不要vue响应式的值

element的el-steps我通过v-for循环展示里面的每一行信息我需要处理&#xff0c;我就用了方法 handlerCatalogue来处理&#xff0c; 我重新定义一个数据lineOneIntro &#xff0c;每次return的lineOneIntro &#xff0c;但是会执行103次&#xff0c; 导致我页面卡死&#xff0c;…

SpringBoot 基于iText 根据PDF模板动态生成文件

SpringBoot 基于iText 根据PDF模板动态生成文件, 需要使用 adobe acrobat pro DC这个工具来自定义模板 支持根据PDF模板生成单页或多页PDF文件 adobe acrobat pro DC 自定义模板 下载地址 链接&#xff1a;https://pan.baidu.com/s/1Vn3bIQ5_D17sEZnkF2t7gg?pwdn6o1 提取码…

【hot100篇-python刷题记录】【杨辉三角】

R6-dp篇 印象题&#xff0c;但做法应该改变了 思路&#xff1a;前两行直接写 next[i]cur[i-1]cur[i]&#xff0c;其中next[0]和next[-1] 这样的话&#xff0c;需要创建2个额外的数组空间&#xff0c;而且还要变化 所以考虑动态规划 class Solution:def generate(self, num…

Efficient LoFTR论文阅读(特征匹配)

Efficient LoFTR论文阅读&#xff08;特征匹配&#xff09; 摘要1. 引言2. 相关工作基于检测器的图像匹配无检测器图像匹配 3. 方法3.1. 局部特征提取3.2. 高效的局部特征变换3.3. 准备工作3.4. 聚合注意力机制3.5 粗级匹配模块有效推理策略子像素级细化模块有效的精细特征提取…

[C语言]一、C语言基础(03.函数)

G:\Cpp\C语言精讲 6. 函数 6.1函数的基本使用 6.1.1 为什么需要函数 《街霸》游戏中&#xff0c;每次人物出拳、出脚或跳跃等动作都需要编写50-80行的代码&#xff0c;在每次出拳、出脚或跳跃的地方都需要重复地编写这50-80行代码&#xff0c;这样程序会变得很臃肿&#xff…

目前kimi算不算国内顶级的AI?

利用AI工具批量生成影视短剧推广https://docs.qq.com/doc/DYnl6d0FLdHp0V2ll 从用户体验上讲&#xff0c;我觉得 Kimi 算得上国内的顶级 AI。 现在的大模型产品遍地开花&#xff0c;底层模型原理差异不大&#xff0c;想要在这样的市场环境中生存下来并赢得普通用户认可&#xf…

Go锁 详解

锁 - Go 函数并发编程中&#xff0c;锁是一种同步机制&#xff0c;用于协调对共享资源的访问&#xff0c;防止数据竞争 - Go 中提供了多种类型的锁&#xff0c;每种锁都有不同的特性和适用场景类型 互斥锁&#xff08;mutex&#xff09; 基础锁&#xff0c;只能同时允许一个 g…

【C++ Primer Plus习题】6.5

问题: 解答: #include <iostream> using namespace std;int main() {float salary 0;float tax 0;while (salary>0){cout << "请输入您的工资:";cin >> salary;if (cin.fail())break;if (salary < 5000){tax 0;}else if (salary < 15…