8.17日作业

将dict.txt中的内容导入到数据库中

  1. 导入后检查解释意思是否完整,双词性

  2. 中间有空格的单词

  3. o'clock

代码部分

#include<stdio.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<string.h>
#include<sqlite3.h>
#define ERR_MSG(msg) do{ \
	fprintf(stderr,"line: %d ", __LINE__); \
	perror(msg);\
}while(0) 


int do_insert(sqlite3* db,char* world,char* mean);
int main(int argc, const char *argv[])
{
	//创建数据库
	sqlite3* db = NULL;
	if(sqlite3_open("./my.db",&db) != SQLITE_OK)
	{
		fprintf(stderr,"__%d__ sqlite3_open failed\n",__LINE__);
		return -1;
	}
	//创建一个表格
	char* sql = "create table if not exists worlds(world char,mean char);";
	char* errmsg = NULL;
	if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK)
	{
		fprintf(stderr,"__%d__ sqlite3_exec:%s\n",__LINE__,errmsg);
		return -1;
	}
	printf("create table success\n");


	//以只读的方式打开单词文件
	FILE* fp = fopen("./dict.txt","r");
	if(NULL == fp)
	{
		ERR_MSG("fopen");
		return -1;
	}



	//将数据从txt文件中读取出来
	char buf[128] = "";
	while(1)
	{	
		if(fgets(buf,sizeof(buf),fp) == NULL)
		{
			printf("已读完\n");
			break;
		}
		buf[strlen(buf)-1] = 0;

		//将单词和词义部分分离开
		char world[20] = "";
		char mean[100] = "";
		int flag = 0;
		int i=0;

		//找到三个空格
		for(i = 0;i<strlen(buf);i++)
		{
			if(flag != 3)
			{
				//如果不是空格则跳过,并把flag置0
				if(buf[i] != ' ')
				{
					flag = 0;
					continue;
				}
				else     //如果为空格,flag+1
				{
					flag++;
				}
			}else
			{
				break;
			}
		}
		//将单词填入数组
		bzero(world,sizeof(world));
		for(int j = 0;j<i-3;j++)
		{
			world[j] = buf[j];
		}

		//将词义存入数组
		bzero(mean,sizeof(mean));	
		int k = 0;

		while(buf[i] != 0)
		{
			mean[k] = buf[i];
			k++;
			i++;
		}
		/*
		for(int k = 0;k<strlen(buf)-i;k++)
		{
			mean[k] = buf[i];
			i++;
		}
*/
		//调用插入函数
		do_insert(db,world,mean);
		
	}


	//关闭文件
	fclose(fp);
	return 0;
}
//将数据写入数据库中
int do_insert(sqlite3* db,char* world,char* mean)
{
	//把单词和词义嵌入数据库插入指令
	char sql[128] = "";
	sprintf(sql,"insert into worlds values(\"%s\",\"%s\");",world,mean);
	printf("sql=%s\n",sql);

	char* errmsg = NULL;
	if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK)
	{
		fprintf(stderr,"__%d__ sqlite3_exec:%s\n",__LINE__,errmsg);
		return -1;
	}
	printf("插入成功\n");
}

运行结果

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值