1. 新建项目dangdangusersearch

2.编写头文件head.h

#ifndef
_HEAD_H_

#define
_HEAD_H_

#include
<stdio.h>   
//注意文件操作相关函数的头文件是stdio.h

#include<stdlib.h>   
//为了使用system函数

#include
<string.h>  
//字符串操作所用到的头文件

#include<Windows.h>  
//使用休眠函数时用到的头文件

#include
<crtdbg.h>  
//做内存泄露检測所需的头文件

//开启内存检測

#define
_CRTDBG_MAP_ALLOC

/*菜单查看*/

extern
void
main_view();

/*获得文件的字节大小*/

extern
int
getFileSize(const
char *path);

/*载入文件,fPath为传递进去的文件路径*/

extern
void
loadFile(const
char *fPath,
const
int
rowSize);

/*通过keyword查找*/

extern
void
findStringByKeyword(const
char *keyword,
const
int
rowSize);

/*查看文件里有多少行*/

extern
int
getFileRow(const
char *path);

/*释放存放每行直至的数组的内存和每行字符串所占的内存*/

extern
void
freeMemory(char
**pp,
const
int
rowSize);

#endif

3.编写main.c

//注意文件操作相关函数的头文件是stdio.h

#include
"head.h"

/*菜单查看*/

void
main_view()

{

system("cls");

printf("\n******************当当用户信息查询系统*******************\n");

printf("\t1.加载数据至内存(-l)\n");

printf("\t2.查找字符串(-s)\n");

printf("\t3.释放内存(-f)\n");

printf("\n*************************0.退出**************************\n");

}

4.编写file.c

#define
_CRT_SECURE_NO_WARNINGS

#include
"head.h"

char **pp
= NULL;
//存储指针数组的地址

FILE *pf
= NULL; 
//定义一个文件指针

int
flag = 0;    
//这个标识符用于推断是否载入完毕,0:标识没有载入,1:表示完毕载入,2:表示释放释放内存

/*获得文件的字节大小*/

int
getFileSize(const
char *path)

{

//依照读取的模式打开

pf =
fopen(path,
"r");

if (pf
== NULL)

{

//代表获取文件失败

return -1;

}

else

{

//fseek():Moves thefile pointer to a specified location.

fseek(pf,
0, SEEK_END);

//ftell( FILE*stream ):文件开头到当前位置有多少个字节

int
num =
ftell(pf);

fclose(pf);//关闭文件

return
num;

}

}

/*载入文件,fPath为传递进去的文件路径*/

void
loadFile(const
char *fPath,
const
int
rowSize)

{

printf("载入文件里,请稍后....");

//pp里面存储的是每行字符串的地址

pp = (char
**)malloc(sizeof(char
*)*rowSize);

pf =
fopen(fPath,
"r");

if (pf
== NULL)

{

printf("对不起,载入文件失败!

");

return;

}

else

{

int
i;

for (i
= 0; i <
rowSize;
i++)

{

//读取字符串的缓冲区

char
str[275] = { 0 };

//*fgets( char*string, int n, FILE *stream );

//从文件里逐行读取字符串

fgets(str,
275, pf);

//获取要分配的字符串长度,最后加一是由于'\0'

int
strlength =
strlen(str)
+ 1;

//分配内存

char *px
= malloc(sizeof(char)*strlength);

//拷贝字符串

strcpy(px,
str);

//设定最后一个字符串为'\0'

px[strlength
- 1] = '\0';

//存储字符串的首地址到指针数组

pp[i]
= px;

}

}

fclose(pf);

flag = 1;

printf("加载内存OK\n");

}

/*通过keyword查找*/

void
findStringByKeyword(const
char *keyword,
const
int
rowSize)

{

if (pp
== NULL)

{

printf("对不起。您还没有载入文件,请您先载入文件\n");

return;

}

int
i;

for (i
= 0; i <
rowSize;
i++)

{

//遍历全部的指针数组的地址。字符串查找

char *ptemp
= strstr(pp[i],
keyword);

if (ptemp
!= NULL)

{

printf("\n%s",
pp[i]);//打印字符串

}

}

}

int
getFileRow(const
char *path)

{

//读取的模式打开

pf =
fopen(path,
"r");

if (pf
== NULL)

{

//代表获取失败

return -1;

}

else

{

int
i = 0;

//是否到文件末尾

while (!feof(pf))

{

char
str[275];

fgets(str,
275, pf);//读取一行

i++;

}

fclose(pf);

return
i;

}

}

/*释放存放每行直至的数组的内存和每行字符串所占的内存*/

void
freeMemory(char
**pp,
const
int
rowSize)

{

printf("正在释放内存,请稍后!

");

int
i;

for (i
= 0; i <
rowSize;
i++)

{

//通过这样的方式释放内存的时候较慢,由于是一行行的释放的

free(pp[i]);

}

free(pp);

flag = 0;

}

5.编写DDSS.c

#define
_CRT_SECURE_NO_WARNINGS

#include
"head.h"

extern
int
flag;

extern
char **pp;

/************************************************************************/

/*
当当用户信息查询系统                                                */

/************************************************************************/

int
main(int
argc,
char *argv[])

{

//文件所在位置

char *path
= "G:\\dangdangwang.txt";

int
fileSize =
getFileSize(path);

//printf("%d字节,%fK,%fM", fileSize, fileSize /1024.0,
fileSize / 1024.0 / 1024.0);

//这个选择菜单是的字符串

char
choice[25];

//获得行号

int
row =
getFileRow(path);

printf("%d\n",
row);

flag:system("cls");

main_view();

if (flag)

{

printf("文件载入完成,能够进行查找了!\n");

}

else
if (flag
== 0)

{

printf("文件未载入状态,请您先载入文件!\n");

}

while (1)

{

printf("输入内容或选择('-v'显示菜单):");

scanf("%24s",
choice);

if (!strcmp(choice,
"-v") || !strcmp(choice,
"-view")){

main_view();

}

else
if (!strcmp(choice,
"-l") || !strcmp(choice,
"-loadFile"))

{

loadFile(path,
row);

}

else
if (!strcmp(choice,
"-s") || !strcmp(choice,
"-search"))

{

while (1)

{

char
keyword[100] = { 0 };

printf("\n请输入要查找的字符串,输入-exit将退出查找\n");

scanf("%s",
keyword);

if (strcmp(keyword,
"-exit"))

{

findStringByKeyword(keyword,
row);

}

else

{

break;

}

}

}

else
if (!strcmp(choice,
"-f") || !strcmp(choice,
"-free"))

{

freeMemory(pp,
row);

}

goto
flag;

}

system("pause");

return 0;

}

将查询到的结果封装到txt文本中

#define
_CRT_SECURE_NO_WARNINGS  
//关闭安全检查

#include
<stdio.h>

#include
<stdlib.h>

void
main()

{

char *path
= "G:\\dangdangwang.txt";

char *respath
= "G:\\1.txt";

FILE *pf;

FILE *fp;

pf =
fopen(path,"r");//读的模式

fp =
fopen(respath,"w");//写的模式

if (pf
== NULL)

{

printf("文件打开失败");

}

else

{

//文件指针到末尾

fseek(pf,
0, SEEK_END);

int
num =
ftell(pf);

char 
strinfo[200];

sprintf(strinfo,
"\nnum=%d字节,%fK,%fM",
num,
num / 1024.0,
num / 1024.0 / 1024.0);

fputs(strinfo,
fp);//写入文件

rewind(pf);//回到文件开头

while (!feof(pf))

{

//缓冲区

char
str[200];

//读取。依照行读取

fgets(str,
200, pf);

if (strstr(str,"谭胜")
!= NULL) 
//字符串查找

{

fputs(str,
fp);//写入文件

printf("\n%s",
str);//打印结果

}

}

fclose(fp);  
//关闭文件

fclose(pf);  
//关闭文件

}

//打开结果文件

system(respath);

system("pause");

}

单线程实现检索当当网泄露的1GB用户数据的更多相关文章

  1. Python爬虫库Scrapy入门1--爬取当当网商品数据

    1.关于scrapy库的介绍,可以查看其官方文档:http://scrapy-chs.readthedocs.io/zh_CN/latest/ 2.安装:pip install scrapy  注意这 ...

  2. 为什么在我眼里你是一只傻逼——傻逼“常所用”句型之(2)——“当当网的就有XXX人评论,YYY%的推荐”

    A:这东西里面尽是大粪. B:这东西当当网的就有325人评论,98.8%的推荐.京东的整体评论是五星,37人评价,31人给好评,1人差评,5人中评:亚马逊有6条好评,1条中评. http://news ...

  3. 当当网开源Dubbox,扩展Dubbo服务框架支持REST风格远程调用

    当当网近日开源了Dubbox项目,可为Dubbo服务框架提供多项扩展功能,包括REST风格远程调用.Kryo/FST序列化等等. 当当网架构部和技术委员会架构师沈理向InfoQ中文站介绍了Dubbox ...

  4. [对话CTO]当当网熊长青:兴趣是成为优秀工程师的第一因素-CSDN.NET

    Women Techmaker 北京站 [对话CTO]当当网熊长青:兴趣是成为优秀工程师的第一因素-CSDN.NET     [对话CTO]当当网熊长青:兴趣是成为优秀工程师的第一因素    发表于2 ...

  5. 网络爬虫之定向爬虫:爬取当当网2015年图书销售排行榜信息(Crawler)

    做了个爬虫,爬取当当网--2015年图书销售排行榜 TOP500 爬取的基本思想是:通过浏览网页,列出你所想要获取的信息,然后通过浏览网页的源码和检查(这里用的是chrome)来获相关信息的节点,最后 ...

  6. 转 当当网资深DBA:DB运维四大现代化的实现

    位好,今天我的主题是 <DB运维的四个现代化> ,看标题就能明白,是关于DBA自动化运维平台的事情.http://dbaplus.cn/news-21-855-1.html 主要是分享下我 ...

  7. java爬虫,爬取当当网数据

     背景:女票快毕业了(没错!我是有女票的!!!),写论文,主题是儿童性教育,查看儿童性教育绘本数据死活找不到,没办法,就去当当网查询下数据,但是数据怎么弄下来呢,首先想到用Python,但是不会!!百 ...

  8. Python 爬虫 当当网图书 scrapy

    目标站点需求分析 获取当当网每个图书名字和评论数 涉及的库 scrapy,mysql 获取解析单页源码 保存到数据库中 结果

  9. Scrapy爬虫(5)爬取当当网图书畅销榜

      本次将会使用Scrapy来爬取当当网的图书畅销榜,其网页截图如下:   我们的爬虫将会把每本书的排名,书名,作者,出版社,价格以及评论数爬取出来,并保存为csv格式的文件.项目的具体创建就不再多讲 ...

随机推荐

  1. Linux下离线安装MySQL

    Linux下安装mysql 1 检查并卸载已安装mysql 命令:rpm -qa|grep -i mysql 命令:rpm -e --nodeps ‘上个命令后显示的本机已安装mysql依赖’ 如果存 ...

  2. [NOIP2015模拟10.22] 最小代价 解题报告 (最小生成树)

    Description 给出一幅由n个点m条边构成的无向带权图.其中有些点是黑点,其他点是白点.现在每个白点都要与他距离最近的黑点通过最短路连接(如果有很多个黑点,可以选取其中任意一个),我们想要使得 ...

  3. <<大学>>原文

    大学之道,在明明德,在亲民,在止于至善.知止而后有定,定而后能静,静而后能安,安而后能虑,虑而后能得.物有本末,事有终始,知所先后,则近道矣. 古之欲明明德于天下者,先治其国,欲治其国者,先齐其家:欲 ...

  4. ATP自造8Gb内存颗粒供DDR3使用

    随着整个行业已经全面转向DDR4内存,不少厂商都陆续停产了DDR3,并准备好了迎接DDR5,但对于很多特殊用户,尤其是网络和嵌入式领域,仍然对DDR3有着强劲且持续的需求. 工业内存存储厂商ATP E ...

  5. Could not create connection to database server. Attempted reconnect 3 times. Giving up.错误

    项目是基于springboot框架,昨天从git上pull代码之后也没有具体看更改的地方,结果运行的时候就报错了. java.sql.SQLNonTransientConnectionExceptio ...

  6. 使用 swoole_process 实现 PHP 进程池

    swoole_process 主要是用来代替 PHP 的 pcntl 扩展.我们知道 pcntl 是用来进行多进程编程的,而 pcntl 只提供了 fork 这样原始的接口,容易使用错误,并且没有提供 ...

  7. 极速响应Excel数据报表请求的一种方法

    摘要 通过缓存和维护Excel Workbook实例,极速响应Excel数据报表请求. 这是一个真实的大数据"云计算"项目中的解决方案,在给定的时间和资源下,只有这种方法是最简单并 ...

  8. ArcSDE学习笔记--------增、删、改、查操作

    建立连接 package org.lq.ssm.gp.controller; import com.esri.sde.sdk.client.SeConnection; import com.esri. ...

  9. 【Oracle错误集锦】:ORA-00119 &amp; ORA-00132

    有时候老天就是爱和你开玩笑,昨天好不easy配置好Oracle.可以用PL/SQL正常登录使用,今天突然就不行了.而且错误十分诡异,没有提示什么错误代码.输入usernamepassword,点击登录 ...

  10. SQL try catch处理

    ALTER PROC usp_AccountTransaction @AccountNum INT, @Amount DECIMAL AS BEGIN BEGIN TRY --Start the Tr ...