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.对查询进行优化,应尽量避免全表扫描,首先应考 ...
随机推荐
- windows server,无桌面服务器 , 批处理更改时区
windows server,无桌面服务器 , 批处理更改时区 time /t cmd.exe /c Control.exe TIMEDATE.CPL,,/Z "China Standard ...
- google浏览器修改网页字符编码
google浏览器修改网页字符编码 直接在google浏览器的应用拓展程序里面搜 Charset,第一个就是 于是就有了
- Aizu - 2564 Tree Reconstruction 并查集
Aizu - 2564 Tree Reconstruction 题意:一个有向图,要使得能确定每一条边的权值,要求是每个点的入权和出权相等,问你最少需要确定多少条边 思路:这题好像有一个定理之类的,对 ...
- HUE配置文件hue.ini 的desktop模块详解(图文详解)(分HA集群)
http://archive.cloudera.com/cdh5/cdh/5/hue-3.9.0-cdh5.5.4/manual.html#_install_hue [desktop]这块,配置如下 ...
- C#中如何获得两个日期之间的天数差 ( c# 计算两个日期之间相差的天数 )
DateTime dtLast = new DateTime(Convert.ToInt32(LastMenses.Year), Convert.ToInt32(LastMenses.Month), ...
- UESTC 1584
http://acm.uestc.edu.cn/#/problem/show/1584 Washi与Sonochi的约定 Time Limit: 3000/1000MS (Java/Others) ...
- 修改mysql 的 字符集 解决中文乱码问题
确定的是自己mysql的字符集是否都是utf8, 通过mysql -u root -p然后输入数据库的密码登陆. 在mysql命令行查询自己的字符集是否都是utf8(除了文件的编码是binary). ...
- Java Web学习总结(21)——http协议响应状态码大全以及常用状态码
http协议响应状态码大全以及常用状态码 当我们在浏览网页或是在查看服务器日志时,常会遇到3位数字的状态码,这3位数字是什么意思呢?其实,这3位数字是HTTP状态码,用来表示网页服务器HTTP响应状态 ...
- Java 实现有序链表
有序链表: 按关键值排序. 删除链头时,就删除最小(/最大)的值,插入时,搜索插入的位置. 插入时须要比較O(N),平均O(N/2),删除最小(/最大)的在链头的数据时效率为O(1), 假设一个应用须 ...
- Android性能优化之提高ListView性能的技巧
ListView优化一直是一个老生常谈的问题.无论是面试还是寻常的开发中,ListView永远不会被忽略掉,那么这篇文章我们来看看怎样最大化的优化ListView的性能. 1.在adapter中的ge ...