//file_op.c

#include <string.h>
#include <stdio.h>
#include <stdlib.h>
struct info{
int id;
char name[];
char sex[];
char col[];
char sub[];
char marks[];
struct info * prev;
struct info * next;
};
typedef struct info *st;
static st head = NULL;//链表头指针
#define PRINT_ST(str) \
"info:id=%d; name=%s; sex=%s;col=%s; sub=%s; marks=%s\n",\
str->id,str->name, str->sex,str->col, str->sub, str->marks
int temp = ;
int break_up(char *buffer);//分割字符串函数
int put_in(char* str[]);//放入结构体
int print_st(st str);//输出结构体,测试用
char * char_filter( char *str);//去掉行末回车符
int insert_list(st p);//插入链表
int main(void)
{
FILE *stream;
char msg[];
char backup[];
st p1, p2;
/* open a file for update */
stream = fopen("file.txt","r");
/* seek to the start of the file */
fseek(stream, , SEEK_SET);//指针指向文件头部
/*备份第一行内容*/
fgets(msg, , stream) != NULL;
strcpy(backup, msg);
/* 从第二行开始去数据 */
while( fgets(msg, , stream) != NULL)
{
printf("%s",msg);
break_up(msg);
memset(msg, , sizeof(msg));
}
/*先读取一行内容,测试用
fgets(msg, 100, stream) != NULL;
printf("%s",msg);
break_up(msg);
*/
fclose(stream);
/*正序输出链表,测试用*/
p1 = head;
puts("\n");
while( p1 != NULL)
{
print_st(p1);
p1 = p1->next;
}
/*倒序输出链表,测试用*/
p1 = head;
puts("\n");
while(p1 != NULL)
{
p2 = p1;
p1 = p1->next;
}
while(p2 != NULL)
{
print_st(p2);
p2 = p2->prev;
} /*下面新建文件,倒叙输出到一个新文件new.txt里面*/
stream = fopen("new.txt","w+");
if(fputs(backup, stream) < )
{
perror("fputs error:");
}
p1 = head;
while(p1 != NULL)
{
p2 = p1;
p1 = p1->next;
}
while(p2 != NULL)
{
snprintf(msg, sizeof(msg), PRINT_ST(p2));
printf("test_char:%s\n",msg);
fputs(msg, stream);
p2 = p2->prev;
} fclose(stream); /*释放链表*/
p1 = head->next;
while (p1 != NULL)
{
p2 = p1;
p1 = p1->next;
free(p2);
}
free(head);
head = NULL;
return ;
}
/*分割字符串*/
int break_up(char *buffer)
{
int i = , j = ;
char *p[]= {NULL};
char *buf=buffer;
char *outer_ptr=NULL;
char *inner_ptr=NULL;
while((p[i]=strtok_r(buf,";",&outer_ptr))!=NULL)
{
i++;
buf=NULL;
}
// printf("Here we have %d strings\n",i);//测试用
for(j= ; j<i; j++)
{
printf("%s\n",p[j]);//输出分割字符串,测试用
}
put_in(p);
return ;
}
/*放入结构体*/
int put_in(char* str[])
{
st st1 = (st)malloc(sizeof(struct info));
st1->id = atoi(str[]);
strcpy(st1->name, str[]);
strcpy(st1->sex, str[]);
strcpy(st1->col, str[]);
strcpy(st1->sub, str[]);
str[] = char_filter(str[]);
strcpy(st1->marks, str[] );
st1->next = NULL;
st1->prev = NULL;
print_st(st1);
if(temp == )
{
head = st1;
temp++;
return ;
}
insert_list(st1);
return ;
}
int print_st(st str)//
{
/* printf("info:id=%d; name=%s; sex=%s; col=%s; sub=%s; marks=%s\n",
str->id,str->name, str->sex, str->col, str->sub, str->marks);
*/
printf(PRINT_ST(str));
}
char *char_filter( char *str)
{
int i = strlen(str);
*(str + i - ) = '\0';
return str;
}
int insert_list(st p)
{ st q = head;
while( q->next != NULL)
{
q = q->next;
}
q->next = p;
p->prev = q;
return ;
}

===================================

file.txt 内容

ID;NAME;SEX;COLLEGE;SUBJECT;REMARKS 
1;jean;male;electron;communicate;no marks 
2;luce;female;legal;legal;thanks 
3;devide;male;building;build;remarks 
4;liulian;female;business;business;arm

===============================================

程序输出:

1;jean;male;electron;communicate;no marks 

jean 
male 
electron 
communicate 
no marks

info:id=1; name=jean; sex=male;col=electron; sub=communicate; marks=no marks 
2;luce;female;legal;legal;thanks 

luce 
female 
legal 
legal 
thanks

info:id=2; name=luce; sex=female;col=legal; sub=legal; marks=thanks 
3;devide;male;building;build;remarks 

devide 
male 
building 
build 
remarks

info:id=3; name=devide; sex=male;col=building; sub=build; marks=remarks 
4;liulian;female;business;business;arm 

liulian 
female 
business 
business 
arm

info:id=4; name=liulian; sex=female;col=business; sub=business; marks=arm

info:id=1; name=jean; sex=male;col=electron; sub=communicate; marks=no marks 
info:id=2; name=luce; sex=female;col=legal; sub=legal; marks=thanks 
info:id=3; name=devide; sex=male;col=building; sub=build; marks=remarks 
info:id=4; name=liulian; sex=female;col=business; sub=business; marks=arm

info:id=4; name=liulian; sex=female;col=business; sub=business; marks=arm 
info:id=3; name=devide; sex=male;col=building; sub=build; marks=remarks 
info:id=2; name=luce; sex=female;col=legal; sub=legal; marks=thanks 
info:id=1; name=jean; sex=male;col=electron; sub=communicate; marks=no marks 
test_char:info:id=4; name=liulian; sex=female;col=business; sub=business; marks=arm

test_char:info:id=3; name=devide; sex=male;col=building; sub=build; marks=remarks

test_char:info:id=2; name=luce; sex=female;col=legal; sub=legal; marks=thanks

test_char:info:id=1; name=jean; sex=male;col=electron; sub=communicate; marks=no marks

LinuxC语言读取文件,分割字符串,存入链表,放入另一个文件的更多相关文章

  1. Java基础知识强化之IO流笔记52:IO流练习之 把一个文件中的字符串排序后再写入另一个文件案例

    1. 把一个文件中的字符串排序后再写入另一个文件 已知s.txt文件中有这样的一个字符串:"hcexfgijkamdnoqrzstuvwybpl" 请编写程序读取数据内容,把数据排 ...

  2. Oracle把逗号分割的字符串转换为可放入in的条件语句的字符数列

    Oracle把逗号分割的字符串转换为可放入in的条件语句的字符数列   前台传来的字符串:'589,321' SELECT*FROM TAB_A T1 WHERE  T1.CODE  IN ( SEL ...

  3. Path,Files巩固,题目:从键盘接收两个文件夹路径,把其中一个文件夹中(包含内容)拷贝到另一个文件夹中

    这个题目用传统的File,InputStream可以做,但是如果用Files,Path类做,虽然思路上会困难一些,但是代码简洁了很多,以下是代码: import java.io.IOException ...

  4. Java文件选择对话框(文件选择器JFileChooser)的使用:以一个文件加密器为例

    文件加密器,操作过程肯定涉及到文件选择器的使用,所以这里以文件加密器为例.下例为我自己写的一个文件加密器,没什么特别的加密算法,只为演示文件选择器JFileChooser的使用. 加密器界面如图: 项 ...

  5. allegro把formate symbol文件从一个文件拷入另一个文件的方法

    allegro画好PCB后经常需要添加一些说明谢谢,比如叠层信息.阻抗表等,但是每次都自己画太麻烦,现在就写下如何重复使用各种格式. 1.打开包含这些信息的板子,FILE-> Export -& ...

  6. git如何删除已经 add 的文件 (如何撤销已放入缓存区文件的修改)

    使用 git rm 命令即可,有两种选择, 一种是 git rm –cached “文件路径”,不删除物理文件,仅将该文件从缓存中删除: 一种是 git rm –f “文件路径”,不仅将该文件从缓存中 ...

  7. Python文件读写 - 读一个文件所有行,加工后写另一个文件

    #Filename: file_read_and_write.py #打开文件,cNames读取所有行,储存在列表中,循环对每一行在起始处加上序号1,2,3,4 with open(r'file/co ...

  8. c++鼠标点点,获取坐标值,放入到txt文件中

    // oj3.cpp : Defines the entry point for the console application.// #include "stdafx.h"#in ...

  9. python 合并两个文件并将合并内容保存在另一个文件中

    简单地文件合并方法 思路如下: 分别读取两个文件中的内容,并将其保存在一个列表中,将列表通过join()函数转为字符,并将新字符保存在新的文件中. 其中,test1.txt中的内容为: test2.t ...

随机推荐

  1. ETHREAD APC 《寒江独钓》内核学习笔记(4)

    继续学习windows 中和线程有关系的数据结构: ETHREAD.KTHREAD.TEB 1. 相关阅读材料 <windows 内核原理与实现> --- 潘爱民 2. 数据结构分析 我们 ...

  2. Bootstrap新手学习笔记——css

    Css模块: 1.网格系统: class前缀:.col-xs-*,.col-sm-*,.col-md-*,.col-lg-* <div class="container"&g ...

  3. Linux里如何查找文件内容 (转)

    Linux查找文件内容的常用命令方法. 从文件内容查找匹配指定字符串的行: $ grep "被查找的字符串" 文件名例子:在当前目录里第一级文件夹中寻找包含指定字符串的.in文件g ...

  4. JS 省,市,区

    // 纯JS省市区三级联动 // 2011-11-30 by http://www.cnblogs.com/zjfree var addressInit = function (_cmbProvinc ...

  5. 让VisualVM+BTrace进入unsafe mode

    让VisualVM+BTrace进入unsafe mode http://kenai.com/projects/btrace/pages/UserGuide BTrace很强大,但有很多安全限制,比如 ...

  6. C语言的一点操作(学习笔记)

    #include <stdio.h> #define LENTEST 100 // 采取逐步删除的方法求的素数 //先假设1-100都是素数,然后剔除2的倍数, //3的倍数,直到剔除所有 ...

  7. 用windbg+sos找出程序中谁占用内存过高,谁占用CPU过高(转载)

    原文地址: http://www.cnblogs.com/Lawson/archive/2011/01/23/1942692.html 很早看到windbg+sos方面的知识,一直没仔细学习,也许因为 ...

  8. 想在BD自然排名中脱颖而出吗?加张合适的图片吧!

    经常在BD或gg搜索不难发现有些搜索结果会带有缩略图,类似下图,图文搭配,看着不累 在一大排搜索结果中,都是文字的话,还没认真看就感觉累,如果在这些搜索结果中突然出现一条图文结合的条目,是不是有耳目一 ...

  9. Radar Installation(贪心)

    Radar Installation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 56826   Accepted: 12 ...

  10. =============Python安装与使用================

    用文本编辑器写Python程序,然后保存为后缀为.py的文件,就可以用Python直接运行这个程序了. Python的交互模式和直接运行.py文件有什么区别呢? 直接输入python进入交互模式,相当 ...