57.大数据线性处理csdn数据(fread,fwrite) 百万数据秒读数据
- 创建结构体存储csdn数据
struct csdn
{
char name[];
char password[];
char email[]; }; - 对于分配的大小要先获取最大的长度,定义如下
//姓名最大长度
int namemax = -;
//密码最大长度
int passmax = -;
//邮件最大长度
int mailmax = -;//获取各部分最大长度
void getmax(char *str)
{
//遍历,把所有'#'转化成'\0'
for (char *p = str; *p != '\0'; p++)
{
if (*p == '#')
{
*p = '\0';
}
}
//max1:姓名的长度
int max1 = strlen(str);
if (max1>namemax)
{
namemax = max1;
}
//max2:密码的长度
char *pstr1 = str + strlen(str) + ;
int max2 = strlen(pstr1);
if (max2>passmax)
{
passmax = max2;
} //max3:email的长度
char *pstr2 = pstr1 + strlen(pstr1) + ;
int max3 = strlen(pstr2);
if (max3>mailmax)
{
mailmax = max3;
}
} - fgets读取到的数据写入到结构体中
//字符串初始化结构体
void init(struct csdn *pdata, char *str)
{
//遍历,把所有'#'转化成'\0'
for (char *p = str; *p != '\0';p++)
{
if (*p=='#')
{
*p = '\0';
}
}
//把姓名copy到结构体中
strcpy(pdata->name, str);
//加字符串长度到字符串后一位'\0',再加1到下一个字符串起始位置
char *pstr1 = str + strlen(str) + ;
//把密码copy到结构体中
strcpy(pdata->password, pstr1);
char *pstr2 = pstr1 + strlen(pstr1) + ;
//把email copy到结构体中
strcpy(pdata->email, pstr2);
} - 读取文件并写入到结构体中,然后在把结构体写到文件中
//写入数据
void readfiletxt()
{
//读取文件
FILE *pfr = fopen("csdn.txt", "r");
//以二进制方式写文件
FILE *pfw = fopen("csdn.bin", "wb"); //如果打开失败则返回
if (pfr==NULL)
{
return;
}
//否则写数据
else
{
//如果没有到文件末尾
while (!feof(pfr))
{
//存取读取到的数据
char str[] = { };
//读取一行
fgets(str, , pfr);
//创建结构体
struct csdn csdn1;
//把读取到到的数据写到结构体中
init(&csdn1, str);
//把结构体写入文件
fwrite(&csdn1, sizeof(struct csdn), , pfw);//写入
} }
//关闭文件
fclose(pfr);
fclose(pfw);
} - 测试代码
void main()
{ FILE *pf = fopen("csdn.bin", "rb+");
while ()
{
printf("请输入你要读取的第N个元素:");
int N;
scanf("%d", &N); struct csdn csdn1 = {};
//移动到相应的结构体位置(注意:fwrite写入的必须是同一种类的,这样才好读取)
fseek(pf, sizeof(struct csdn)*(N - ), SEEK_SET);
//读取
fread(&csdn1, sizeof(struct csdn), , pf);
//输出结果
printf("\n%s,%s,%s", csdn1.name, csdn1.password, csdn1.email);
}
fclose(pf);
system("pause");
}
完整代码:
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h> //csdn结构体
struct csdn
{
char name[];
char password[];
char email[]; };
//姓名最大长度
int namemax = -;
//密码最大长度
int passmax = -;
//邮件最大长度
int mailmax = -; //字符串初始化结构体
void init(struct csdn *pdata, char *str)
{
//遍历,把所有'#'转化成'\0'
for (char *p = str; *p != '\0';p++)
{
if (*p=='#')
{
*p = '\0';
}
}
//把姓名copy到结构体中
strcpy(pdata->name, str);
//加字符串长度到字符串后一位'\0',再加1到下一个字符串起始位置
char *pstr1 = str + strlen(str) + ;
//把密码copy到结构体中
strcpy(pdata->password, pstr1);
char *pstr2 = pstr1 + strlen(pstr1) + ;
//把email copy到结构体中
strcpy(pdata->email, pstr2);
} //获取各部分最大长度
void getmax(char *str)
{
//遍历,把所有'#'转化成'\0'
for (char *p = str; *p != '\0'; p++)
{
if (*p == '#')
{
*p = '\0';
}
}
//max1:姓名的长度
int max1 = strlen(str);
if (max1>namemax)
{
namemax = max1;
}
//max2:密码的长度
char *pstr1 = str + strlen(str) + ;
int max2 = strlen(pstr1);
if (max2>passmax)
{
passmax = max2;
} //max3:email的长度
char *pstr2 = pstr1 + strlen(pstr1) + ;
int max3 = strlen(pstr2);
if (max3>mailmax)
{
mailmax = max3;
}
} //写入数据
void readfiletxt()
{
//读取文件
FILE *pfr = fopen("csdn.txt", "r");
//以二进制方式写文件
FILE *pfw = fopen("csdn.bin", "wb"); //如果打开失败则返回
if (pfr==NULL)
{
return;
}
//否则写数据
else
{
//如果没有到文件末尾
while (!feof(pfr))
{
//存取读取到的数据
char str[] = { };
//读取一行
fgets(str, , pfr);
//创建结构体
struct csdn csdn1;
//把读取到到的数据写到结构体中
init(&csdn1, str);
//把结构体写入文件
fwrite(&csdn1, sizeof(struct csdn), , pfw);//写入
} }
//关闭文件
fclose(pfr);
fclose(pfw);
} void main()
{ FILE *pf = fopen("csdn.bin", "rb+");
while ()
{
printf("请输入你要读取的第N个元素:");
int N;
scanf("%d", &N); struct csdn csdn1 = {};
//移动到相应的结构体位置(注意:fwrite写入的必须是同一种类的,这样才好读取)
fseek(pf, sizeof(struct csdn)*(N - ), SEEK_SET);
//读取
fread(&csdn1, sizeof(struct csdn), , pf);
//输出结果
printf("\n%s,%s,%s", csdn1.name, csdn1.password, csdn1.email);
}
fclose(pf);
system("pause");
}
57.大数据线性处理csdn数据(fread,fwrite) 百万数据秒读数据的更多相关文章
- [Linux]read/write和fread/fwrite有什么区别
转自:http://blog.csdn.net/xiaofei0859/article/details/51145051 二者都是对文件进行操作,那么二者有什么区别,用的时候该如何选择呢? 1. 区别 ...
- 使用Javascript/jQuery将javascript对象转换为json格式数据 - 海涛的CSDN博客 - 博客频道 - CSDN.NET
body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...
- (转载)RTMP协议中的AMF数据 http://blog.csdn.net/yeyumin89/article/details/7932585
为梦飞翔 (转载)RTMP协议中的AMF数据 http://blog.csdn.net/yeyumin89/article/details/7932585 这里有一个连接,amf0和amf3的库, ...
- sql处理百万级以上的数据提高查询速度的方法
原文:http://blog.csdn.net/zhengyiluan/article/details/51671599 处理百万级以上的数据提高查询速度的方法: 1.应尽量避免在 where 子句中 ...
- 数据抓取的艺术(一):Selenium+Phantomjs数据抓取环境配置
数据抓取的艺术(一):Selenium+Phantomjs数据抓取环境配置 2013-05-15 15:08:14 分类: Python/Ruby 数据抓取是一门艺术,和其他软件不同,世界上 ...
- echarts异步数据加载(在下拉框选择事件中异步更新数据)
接触echarts 大半年了,从不会到熟练也做过不少的图表,隔了一段时间没使用这玩意,好多东西真心容易忘了.在接触echarts这期间也没有总结什么东西,今天我就来总结一下如何在echart中异步加载 ...
- 关于mysql处理百万级以上的数据时如何提高其查询速度的方法
1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉 ...
- python小知识-属性查询优先级(如果有同名类属性、数据描述符、实例属性存在的话,实例>类>数据描述符)
https://www.cnblogs.com/Jimmy1988/p/6808237.html https://segmentfault.com/a/1190000006660339 https:/ ...
- 《转》sql处理百万级以上的数据提高查询速度的方法
处理百万级以上的数据提高查询速度的方法: 1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考 ...
随机推荐
- 用motion实现家庭视频监控
需求?当然不是为了艳照.你们这些猥琐的人类! 毕竟家里总会有没人的时候,出门走到半路忘记煤气灶是不是关了,还得回去看看. 在这个科技以人为本的时代,当然应该是拿出智能手机联网看看啦.还有万一有人闯空门 ...
- Hadoop2.2集群安装配置-Spark集群安装部署
配置安装Hadoop2.2.0 部署spark 1.0的流程 一.环境描写叙述 本实验在一台Windows7-64下安装Vmware.在Vmware里安装两虚拟机分别例如以下 主机名spark1(19 ...
- vue14 自定义过滤器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- POJ 3622 multiset
思路: 放一个链接 是我太懒了 http://blog.csdn.net/mars_ch/article/details/52835978 嗯她教的我(姑且算是吧) (一通乱搞就出来了-) //By ...
- 在Windows上如何安装和彻底卸载Adobe Flash Player教程
很多小伙伴在安装水晶易表的时候,经常会遇到“Xcelsius2008需要使用Adobe Flash Player(9.151或者更高版本)”报错问题,如下图所示. 导致安装进程受阻,此时就需要安装高版 ...
- Fedora 29 Linux发行版发布,新功能使Web开发人员的工作更方便
Matthew Miller宣布发布Fedora 29.这个项目的最新版本是在Fedora Core 1发布后几乎整整15年才发布的,并且可以在多个版本中用于多个体系结构. 最新版本的Fedora已经 ...
- or in 、Object.keys()以及Object.getOwnPropertyNames有什么区别?
or in .Object.keys()以及Object.getOwnPropertyNames的区别 var obj= Object.create(parent, { b: { value: 2, ...
- 【例题 7-11 UVA - 12325】Zombie's Treasure Chest
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 1.N/s1 < 1e6 枚举1的个数 2.N/s2<1e6 枚举2的个数 3.s1和s2的值较小 假设买了s2个1和s ...
- 【CS Round #37 (Div. 2 only) A】Boring Number
[Link]:https://csacademy.com/contest/round-37/task/boring-number/ [Description] 让你找离平均数最近的一个数的下标; [S ...
- Linux 下查看某进程的线程数
1.查看文件 /proc/${pid}/status2.pstree -p ${pid}3.输入 top -bH -d 3 -p ${pid}top -H手册中说:-H : Threads toggl ...