在C语言中操作文本文件(.txt)中的数据通常需要结合文件I/O函数和字符串处理技术,因为文本文件本身并非结构化数据库,而是以字符形式存储的数据记录,以下是详细步骤和代码示例,说明如何打开、读取和解析txt文件中的“数据库”数据。

文件准备与数据格式
假设txt文件名为data.txt如下(每行一条记录,字段用逗号分隔):
1,张三,25,北京
2,李四,30,上海
3,王五,28,广州 这种格式类似CSV(逗号分隔值),是文本文件存储数据的常见方式。
核心步骤与代码实现
(1)包含头文件
#include <stdio.h> #include <stdlib.h> #include <string.h>
(2)定义数据结构
为每条记录定义结构体,方便存储解析后的数据:

typedef struct {
int id;
char name[20];
int age;
char city[20];
} Record; (3)打开文件
使用fopen()函数以读取模式打开文件,需检查文件是否成功打开:
FILE *file = fopen("data.txt", "r");
if (file == NULL) {
perror("无法打开文件");
exit(EXIT_FAILURE);
} (4)逐行读取与解析
通过fgets()读取每行数据,用strtok()分割字符串:
char line[100];
Record records[100]; // 假设最多存储100条记录
int count = 0;
while (fgets(line, sizeof(line), file)) {
// 去除换行符
line[strcspn(line, "n")] = ' ';
// 分割字符串
char *token = strtok(line, ",");
records[count].id = atoi(token); // 转换为整数
token = strtok(NULL, ",");
strcpy(records[count].name, token);
token = strtok(NULL, ",");
records[count].age = atoi(token);
token = strtok(NULL, ",");
strcpy(records[count].city, token);
count++;
} (5)关闭文件
fclose(file);
(6)完整代码示例
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct {
int id;
char name[20];
int age;
char city[20];
} Record;
int main() {
FILE *file = fopen("data.txt", "r");
if (file == NULL) {
perror("无法打开文件");
return 1;
}
char line[100];
Record records[100];
int count = 0;
while (fgets(line, sizeof(line), file)) {
line[strcspn(line, "n")] = ' ';
char *token = strtok(line, ",");
records[count].id = atoi(token);
token = strtok(NULL, ",");
strcpy(records[count].name, token);
token = strtok(NULL, ",");
records[count].age = atoi(token);
token = strtok(NULL, ",");
strcpy(records[count].city, token);
count++;
}
fclose(file);
// 打印解析结果
for (int i = 0; i < count; i++) {
printf("ID: %d, 姓名: %s, 年龄: %d, 城市: %sn",
records[i].id, records[i].name, records[i].age, records[i].city);
}
return 0;
} 关键函数说明
| 函数 | 功能 |
|---|---|
fopen() | 打开文件,返回文件指针,参数:”文件路径”, “模式”(如”r”为读取)。 |
fgets() | 从文件中读取一行,存储到指定缓冲区。 |
strtok() | 分割字符串,通过指定分隔符(如逗号)提取子串。 |
atoi() | 将字符串转换为整数。 |
strcpy() | 复制字符串到目标缓冲区。 |
fclose() | 关闭文件指针,释放资源。 |
注意事项
- 错误处理:需检查文件是否成功打开、
fgets()是否返回NULL(文件结束或错误)。 - 缓冲区溢出:
fgets()的缓冲区大小需足够容纳一行数据,避免溢出。 - 数据格式:若字段包含逗号或换行符,需更复杂的解析逻辑(如引号包裹)。
- 内存管理:动态分配内存(如
malloc)可避免固定大小数组的限制。
相关问答FAQs
Q1: 如果txt文件中的字段数量不固定,如何处理?
A1: 可通过循环调用strtok(NULL, ","),直到返回NULL,并动态调整结构体数组大小。

int field_count = 0;
char *token = strtok(line, ",");
while (token != NULL) {
// 存储字段到临时数组
token = strtok(NULL, ",");
field_count++;
} Q2: 如何处理文件中的中文乱码问题?
A2: 乱码通常因编码不匹配导致,需确保文件编码(如UTF-8)与程序一致,可通过以下方式解决:
- 用文本编辑器保存文件为UTF-8编码。
- 在Windows系统中,以二进制模式打开文件(
"rb"),并使用宽字符函数(如fgetws)读取。
【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!
发表回复