• 创建结构体存储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) 百万数据秒读数据的更多相关文章

  1. [Linux]read/write和fread/fwrite有什么区别

    转自:http://blog.csdn.net/xiaofei0859/article/details/51145051 二者都是对文件进行操作,那么二者有什么区别,用的时候该如何选择呢? 1. 区别 ...

  2. 使用Javascript/jQuery将javascript对象转换为json格式数据 - 海涛的CSDN博客 - 博客频道 - CSDN.NET

    body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...

  3. (转载)RTMP协议中的AMF数据 http://blog.csdn.net/yeyumin89/article/details/7932585

    为梦飞翔   (转载)RTMP协议中的AMF数据 http://blog.csdn.net/yeyumin89/article/details/7932585 这里有一个连接,amf0和amf3的库, ...

  4. sql处理百万级以上的数据提高查询速度的方法

    原文:http://blog.csdn.net/zhengyiluan/article/details/51671599 处理百万级以上的数据提高查询速度的方法: 1.应尽量避免在 where 子句中 ...

  5. 数据抓取的艺术(一):Selenium+Phantomjs数据抓取环境配置

     数据抓取的艺术(一):Selenium+Phantomjs数据抓取环境配置 2013-05-15 15:08:14 分类: Python/Ruby     数据抓取是一门艺术,和其他软件不同,世界上 ...

  6. echarts异步数据加载(在下拉框选择事件中异步更新数据)

    接触echarts 大半年了,从不会到熟练也做过不少的图表,隔了一段时间没使用这玩意,好多东西真心容易忘了.在接触echarts这期间也没有总结什么东西,今天我就来总结一下如何在echart中异步加载 ...

  7. 关于mysql处理百万级以上的数据时如何提高其查询速度的方法

    1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉 ...

  8. python小知识-属性查询优先级(如果有同名类属性、数据描述符、实例属性存在的话,实例>类>数据描述符)

    https://www.cnblogs.com/Jimmy1988/p/6808237.html https://segmentfault.com/a/1190000006660339 https:/ ...

  9. 《转》sql处理百万级以上的数据提高查询速度的方法

    处理百万级以上的数据提高查询速度的方法: 1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考 ...

随机推荐

  1. 1193 Eason

    Eason Acceteped : 57   Submit : 129 Time Limit : 1000 MS   Memory Limit : 65536 KB Description 题目描述 ...

  2. centos7 安装rsyslog

    http://blog.csdn.net/u011630575/article/details/50896781 http://blog.chinaunix.net/uid-21142030-id-5 ...

  3. 洛谷—— P1877 [HAOI2012]音量调节

    https://www.luogu.org/problem/show?pid=1877#sub 题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要 ...

  4. EBS 第一个项目 学习总结 ---- 发运模块

    EBS 组织架构: (一)业务组(BG) (二)法律实体(LE) (三)业务实体(OU) (四)库存组织(INV) (五)公司成本中心(Cost Center) (六)HR组织 (七)多组织接入控制 ...

  5. ASIHTTPRequest导入出错-libxml出错, i386 "_deflate"

    导入需要 ASIHTTPRequest 依赖于以下5个框架或库: CFNetwork, SystemConfiguration,MobileCoreServices, CoreGraphics 和 l ...

  6. VC双缓冲画图技术介绍

    双缓冲画图,它是一种主要的图形图像画图技术.首先,它在内存中创建一个与屏幕画图区域一致的对象,然后将图形绘制到内存中的这个对象上,最后把这个对象上的图形数据一次性地拷贝并显示到屏幕上. 这样的技术能够 ...

  7. JsonRequestBehavior.AllowGet 方便浏览器调试

    [HttpGet] public ActionResult getCoversationList(int CustomerId) { // 获取用户相关的聊天数据,包括个人,群,系统(可以单独获取) ...

  8. 快速select算法的实现

    代码来自: http://blog.csdn.net/v_JULY_v 算法思想: // Quick_select.cpp : 定义控制台应用程序的入口点. // #include "std ...

  9. js library 集合

    js library 集合 查看已经开源的js library https://cdnjs.com/

  10. 重大漏洞:Bitlocker成摆设,多款固态硬盘硬件加密均可被绕过

    荷兰拉德堡德大学的两名研究人员日前发表论文,描述了固态硬盘流行加密软件Bitlocker中的关键漏洞.固态硬盘需要口令来加密和解密其上存储的内容,但该口令可以被绕过. 荷兰拉德堡德大学的两名研究人员日 ...