【C进阶】文件操作(下)(详解--适合初学者入门)

news2024/11/24 6:35:57

目录

补充的知识点:>

标准流

FILE型

fopen(打开文件)

fclose(关闭文件)

5.文件的随机读写💻

5.1 fwrite📂

5.2fread📂

5.3fseek📂

 5.4 ftell📂

 5.5 rewind📂

6.文本文件和二进制文件💻

7.文件读取结束的判定✅ 

8. 文件缓冲区💥

9.实现一个代码,拷贝一个文件打开文件,打开被读的文件


前言: 这篇文章是关于文件操作的下半篇,由于本章的篇幅较长,所以分两篇总结本章知识,这是文件操作上半篇的链接 http://t.csdn.cn/RkaMo
需要的小伙伴们可以去浏览一下喔,最后,感谢您的来访!

在讲这一章之前我想补充一些知识:

补充的知识点:>

标准流

标准流有三种:关于流的知识上一章有设计到,可以去看一下。

stdin - 标准输入流(standard input stream)

用于读取普通输入的流,在大多数环境中从键盘中为从键盘输入。scanfgetchar等函数会从这个流中读取字符。

stdout - 标准输出流(standard output stream)

用于写入普通输出的流,在大多数环境中为输出至显示器界面,printf、puts与putchar等函数会向这个流写入字符。

stderr - 标准错误流(standard error stream)

用于写出错误的流。在大多数环境中为输出至显示器界面。

FILE型

表示标准流的stdin、stdout、stderr都是指向FILE型的指针型。FILE型要在头文件<stdio.h>中定义,该数据类型用于记录控制流所需要的信息,其中包括以下数据

文件位置指示符(file position indicator)

记录当前访问地址。

错误指示符(error indicator)

记录是否发生了读取错误或写入错误。

文件结束指示符(EOF indicator) 

记录是否已到达文件末尾。

通过流进行的输入输出都是根据上述信息执行操作的。而且这些信息也会随着操作结果更新。FILE 型的具体实现方法因编译器而异,一般多以结构体的形式实现。

fopen(打开文件)

大家在使用纸质笔记本时通常都是先打开,然后再翻页阅读或在适当的地方书写。

程序中的文件处理过程也同样如此。首先打开文件并定位到文件开头,然后找到要读取或写入的目标位置进行读写操作,最后将文件关闭。

打开文件的操作称为打开(open)。函数库中的fopen函数用于打开文件。

注意:使用文件时,需要事先用fopen函数打开文件。

该函数需要两个参数。第1个参数是要打开的文件名,第2个参数是文件类型及打开模式。以下图为例,使用"r”模式打开文件"abc.txt"。

  • 文件类型有两种,即文本文件和二进制文件。接下来会讲到。

        fopen函数会为要打开的文件新建一个流,然后返回一个指向FILE型对象的指针,该FILE型对象中保存了控制这个流所需要的信息。
        文件一旦打开后,就可以通过FILE *型指针对流进行操作。

  •  和程序启动时便准备好的标准流不同,要打开文件时必须先在程序中定义FILE * 型的指针变量。然后将fopen函数返回的指针赋于该变量,就可以通过该指针变量对文件进行操作了。

变量可以任意命名,这里我们将它命名为fp。fp不是流的实体,而是指向流的指针,严格来讲应称之为“指针fp所指向的流”。

fclose(关闭文件)

当我们读完一本书时会将它合上,文件也同样如此。在文件使用结束后,就要断开文件与流的关联将流关闭。这个操作就称为关闭(close)文件。
以下是用于关闭文件的fclose函数说明。
 

fclose
头文件#include<stdio.h>
原型int fclose(FILE *stream);
说明刷新stream所指向的流,然后关闭与该流相关联的文件。流中留在缓冲区里面尚未写入的数据会被传递到宿主环境”,由宿主环境将这些数据写入文件。而缓冲区里面尚未读取的数据将被丢弃。然后断开流与文件的关联。如果存在系统自动分配的与该流相关联的缓冲区,则会释放该缓冲区。
返回值若成功地关闭流,则返回0。检查到错误时返回EOF。

下图为关闭文件的示意图。只要将打开文件时fopen函数返回的指针传给fclose函数即可。

5.文件的随机读写💻

5.1 fwrite📂

fwrite用于函数的读取以下为说明:

fwrite
头文件#include<stdio.h>
原型size_t fwrite (const void *ptr, size_t size,size_t nmemb,FILE *stream) ;
说明从ptr指向的数组中将最多nmemb个长度为size的元素写入stream指向的流中。若定义了流的文件位置指示符,则以成功写入的字符数为单位向前移动。当发生错误时,该流的文件位置指示符的值不可预测。
返回值返回成功写入的元素个数。仅当发生写入错误时,元素个数会少于nmemb。

 实例代码:二进制输出(二进制的写)

#include<stdio.h>
//fwrite
struct S
{
	char name[20];
	int age;
	float score;
};
int main()
{
	struct S s={"zhangsan",20,95.5f};
	FILE* pf = fopen("test.aaa", "wb");//这个后缀.aaa可以任意命名
	if (pf == NULL)
	{
		perror("fopen");
		return 0;
	}
	fwrite(&s, sizeof(struct S), 1, pf);

	//关闭文件
	fclose(pf);
	return 0;
}

 执行:以二进制的信息写进文本文件,记事本打开,我们肉眼看不懂,

5.2fread📂

fread
头文件#include<stdio.h>
原型size_t fread (const void *ptr, size_t size,size_t nmemb,FILE *stream);
说明从stream指向的流中最多读取nmemb个长度为size的元素到ptr指向的数组。若定义了流的文件位置指示符,则以成功读取的字符数为单位向前移动。当发生错误时,该流的文件位置指示符的值不可预测。只读取到某一元素的部分内容时,值不可预测。
返回值

返回成功读取的元素个数。当发生读取错误或达到文件末尾时,元素个数会少于nmemb。

若size或nmemb为0,则返回0。这时数组内容和流的状态都不发生变化。

 实例到代码::二进制输入 (二进制的读)

struct S
{
	char name[20];
	int age;
	float score;
};
int main()
{
	struct S s = { 0 };
	FILE* pf = fopen("test.aaa","rb");//二进制的读
	if (pf == NULL)
	{
		perror("fopen");
		return 0;
	}
    //读文件
	fread(&s, sizeof(struct S), 1, pf);
	printf("%s %d %f", s.name, s.age, s.score);
	//关闭文件
	fclose(pf);
	pf = NULL;
}

执行: 

关于fwrite和fread:

这两个函数会接收4个参数。第一个参数是指向读写数据的首地址的指针,第二个参数是数据的长度,第三个参数是数据的个数,第四个参数是指向读写对象的流的指针

5.3fseek📂

根据文件指针的位置和偏移量来定位文件指针。

int fseek ( FILE * stream, long int offset, int origin );

 图解:

主动把文件的内容改成:要找的字符是b

 图解:

 

实例代码:

#include<stdio.h>
int main()
{
	FILE* pf = fopen("test.aaa","r");
	if (pf == NULL)
	{
		perror("fopen");
		return 1;
	}
	int ch = fgetc(pf);
	printf("%c\n", ch);
	ch = fgetc(pf);
	printf("%c\n", ch);
	ch = fgetc(pf);
	printf("%c\n", ch);
	ch = fgetc(pf);
	printf("%c\n", ch);
	ch = fgetc(pf);
	printf("%c\n", ch);
	//希望读到的是b--想读那个位置就读哪个位置
	//fseek(pf, -4, SEEK_CUR);
	//fseek(pf, 1, SEEK_SET);
	fseek(pf, -7, SEEK_END);
	ch = fgetc(pf);
	printf("%c\n", ch);

	//关闭文件
	fclose(pf);
	pf = NULL;
	return 0;
}

执行: 

关于rewind函数:

 5.4 ftell📂

返回文件指针相对于起始位置的偏移量
long int ftell ( FILE * stream );

#include<stdio.h>
int main()
{
    FILE* pf = fopen("test.aaa","r");
    if (pf == NULL)
    {
        perror("fopen");
        return 1;
    }
    int ch = fgetc(pf);//a
    printf("%c\n", ch);
    ch = fgetc(pf);//b
    printf("%c\n", ch);
    ch = fgetc(pf);//c
    printf("%c\n", ch);
    ch = fgetc(pf);//d
    printf("%c\n", ch);
    ch = fgetc(pf);//e
    printf("%c\n", ch);
    //希望读到的是b--想读那个位置就读哪个位置
 

    printf("%d\n", ftell(pf));//此时pf指向的是f,与a字符相差5个char

    

//关闭文件
    fclose(pf);
    pf = NULL;
    return 0;
}

执行: 

 5.5 rewind📂

让文件指针的位置回到文件的起始位置

#include<stdio.h>

int main()
{
    FILE* pf = fopen("test.aaa", "r");
    if (pf == NULL)
    {
        perror("fopen");
        return 1;
    }
    //读文件
    int ch = fgetc(pf);//a
    printf("%c\n", ch);
     ch = fgetc(pf);//b
    printf("%c\n", ch);
     ch = fgetc(pf);//c
    printf("%c\n", ch);
     ch = fgetc(pf);//d
    printf("%c\n", ch);
  

 rewind(pf);//重新回到起始位置
  

 printf("%d\n", ftell(pf));//与起始位置的偏移量

   ch = fgetc(pf);//从a开始
    printf("%c\n", ch);
}

执行: 

6.文本文件和二进制文件💻

根据数据的组织形式,数据文件被称为 文本文件 或者 二进制文件
文本文件:📂
我们打开之后通过文本文件的类型是能看得懂的,知道里面放的是什么内容,一眼就可以看得懂
二进制文件:📂
 二进制的信息,用文本文件打开是看不懂的。
(这里不算是压缩文件,因为压缩是在已有的数据格式再进行压缩的,这里是原模原样把数据按不同的组织形式存起来)
数据在内存中以二进制的形式存储,如果不加转换的输出到外存,就是 二进制文件
也就是说内存里的数据不做任何转换直接存到文件里面去,这就是 二进制文件 

如果要求在外存上以ASCII码的形式存储,则需要在存储前转换。以ASCII字符的形式存储的文件就是本文件

一个数据在内存中是怎么存储的呢?

字符一律以ASCII形式存储,数值型数据既可以用ASCII形式存储,也可以使用二进制形式存储。

如有整数10000,如果以ASCII码的形式输出到磁盘,则磁盘中占用5个字节(每个字符一个字节),而二进制形式输出,则在磁盘上只占4个字节(VS2013测试)。

图解: 

二进制形式输出为什么占用4字节?
因为10000是一个整数(int),一个int占用4个字节的空间 

创建一个int  a变量,那么a=10000,10000(10进制),它的二进制表示形式为:

 可以看到二进制的表达形式为00 00 27 10 -->小端存储形式:10 27 00 00(下面有演示图)

解释一下 ASCII码的形式 输出到磁盘,为什么占用5个字节:
因为 10000 5位如果以ascll码值的形式存到硬盘里面去的时候 '1''0''0''0''0' 5个字符存到硬盘里面去,那就是5个字节

测试代码:

#include<stdio.h>
int main()
{
    int a = 10000;
    FILE* pf = fopen("test.txt", "wb");
    fwrite(&a, 4, 1, pf);//二进制的形式写进文件中
    fclose(pf);
    pf = NULL;
    return 0;

}

二进制文件展现:💻

把test.txt文本文件添加进编译器之后,右键可以按照以下的流程可以看到10000在内存中的存储情况:10000它的二进制序列以小端的方式存储到内存里面,内存里面的数据不加任何转换直接以小端的形式的顺序写到文件里面去,这种文件就被称为2进制文件

7.文件读取结束的判定✅ 

牢记:在文件读取过程中,不能用 feof 函数的返回值直接用来判断文件的是否结束
就是说feof是等到文件读取结束之后去判断,而不是一边读取一边判断。
这个写法是错的:
while(!feof(pf))
{
}
而是 应用于当文件读取结束的时候,判断是读取失败结束,还是遇到文件尾结束
例如:
1. 文本文件读取是否结束,判断返回值是否为 EOF fgetc ),或者 NULL fgets
  • fgetc 判断是否为 EOF .
  • fgets 判断返回值是否为 NULL
2. 二进制文件的读取结束判断,判断返回值是否小于实际要读的个数。
例如:
  • fread判断返回值是否小于实际要读的个数。
关于feof: 遇到文件末尾了,使用feof来检测这个状态(feof函数是直接判断文件是否读到文件末尾的)
关于ferror:遇到了错误,使用ferror来检测这个状态

总结fgetc:

1.遇到文件末尾,返回EOF,同时设置一个状态,遇到文件末尾了,使用feof来检测这个状态

⒉.遇到错误,返回EOF,同时设置一个状态,遇到了错误,使用ferror来检测这个状态

fgetc
头文件#include<stdio.h>
原型int fgetc(FILE *stream);
说明从stream指向的输入流(若存在)中读取unsigned char型的下一个字符的值,并将它转换为int型。然后,若定义了流的文件位置指示符,则将其向前移动。
返回值

返回stream所指输入流中的下一个字符。若在流中检查到文件末尾,则设置该流的文件结束指示符并返回EOF。如果发生读取错误,就设置该流的错误指示符并返回EOF。

实例代码:

#include<stdio.h>
int main()
{
	FILE* pf = fopen("test.txt", "r");
	if (pf == NULL)
	{
		return 1;
	}
	//读文件
	int ch = 0;
	while ((ch = fgetc(pf)) != EOF)
	{
		printf("%c ", ch);
	}
	fclose(pf);
	pf = NULL;
	return 0;
}

 执行:(前提已经往里面写好了数据)

如何让fgetc在读取中途失败呢?

写法1:

首先把文件删掉 

其次把代码改成:

#include<stdio.h>
int main()
{
	FILE* pf = fopen("test.txt", "r");//这个位置写成"r"
	if (pf == NULL)
	{
		return 1;
	}
	//读文件
	int ch = 0;
	while ((ch = fgetc(pf)) != EOF)
	{
		printf("%c ", ch);
	}
	fclose(pf);
	pf = NULL;
	return 0;
}

执行: 

写法2:如果文件中字符不等于10个,就会读取失败(举例)

#include<stdio.h>
#include <stdlib.h>
int main() {
	FILE* fp;
	char str[20];
	fp = fopen("test.txt", "r");
	if (fp == NULL) {
		printf("打开文件失败\n");
		exit(EXIT_FAILURE);
	}

	if (fread(str, sizeof(char), 9, fp) != 10) {
		printf("读取文件失败\n");
		exit(EXIT_FAILURE);
	}

	fclose(fp);
	return 0;
}

执行:

前提是我的文件写入26个字母

 这里要读取的就是9个字符

 8. 文件缓冲区💥

        ANSIC 标准采用 缓冲文件系统 处理的数据文件的,所谓缓冲文件系统是指系统自动地在内存中为程序中每一个正在使用的文件开辟一块“ 文件缓冲区 。从内存向磁盘输出数据会先送到内存中的缓冲区,装满缓冲区后才一起送到磁盘上。如果从磁盘向计算机读入数据,则从磁盘文件中读取数据输入到内存缓冲区(充满缓冲区),然后再从缓冲区逐个地将数据送到程序数据区(程序变量等),缓冲区的大小根据C编译系统决定的。
画图:写一个程序( 黄色那块区域,   ),创建了很多变量、数组等等,它们都在内存( 蓝色的那块区域)里面。 橘黄色的那块就是我们的缓冲区:输出缓冲区和输入缓冲区。
         当我们想把我们程序的数据写到硬盘上(也就是文件里面去的时候),不是直接就写到硬盘里面去,而是先写到输出缓冲区里面去,当缓冲区放满了或者说主动把数据放到硬盘里面,它自动再把输出缓冲区的数据放到硬盘里面去。
        
         而输入的时候,从硬盘里读数据放到输入缓冲区,然后再把输入缓冲区的数据放到程序数据区里面去。

        其实这就是一个提高效率的问题:就以fwrite为例吧,操作系统可以从电脑里面写数据与读数据,提供了一堆的API(接口),c语言凭什么可以操作文件呢?其实因为操作系统有一些接口可以操作文件。而fwrite是c语言的一个函数,通过利用fwrite函数写的一个代码称为用户程序,用户程序调用操作系统提供的一些接口然后去操作文件的。

 

         所以说调用这些函数写文件或者读文件的时候严格来说会频繁打断操作系统,所以说能不能写上一堆然后一次搞定呢?所以就提供了输入和输出缓冲区。一个同学一次问10个问题和频繁地分时间问问题的效果是一样的,只是效率问题,这个资源就可以腾出来给其他同学服务。

实例代码理解缓冲区问题:
//VS2013 WIN10环境测试
//#include<stdio.h>
//#include<stdlib.h>
//#include<Windows.h>
int main()
{
	FILE* pf = fopen("test.txt", "w");
	fputs("abcdef", pf);//先将代码放在输出缓冲区
	printf("睡眠10秒-已经写数据了,打开test.txt文件,发现文件没有内容\n");
	Sleep(10000);
	printf("刷新缓冲区\n");
	fflush(pf);//刷新缓冲区时,才将输出缓冲区的数据写到文件(磁盘)
	//注:fflush 在高版本的VS上不能使用了
	printf("再睡眠10秒-此时,再次打开test.txt文件,文件有内容了\n");
	Sleep(10000);
	fclose(pf);
	//注:fclose在关闭文件的时候,也会刷新缓冲区
	pf = NULL;
	return 0;
}

睡眠sleep就是,程序在这停止了,不继续往下执行,停了10秒后,再继续执行,这样有助于我们

观察数据从缓冲区到文件的过程。

不写fflush刷新会写入到文件里面吗?

可以理解为提前写入了。因为本来他计划的是程序执行结束之后再将缓冲区中的数据写入,现在是程序结束之前将数据写入文件。

9.实现一个代码,拷贝一个文件打开文件,打开被读的文件

int main()
{
	//实现一个代码,拷贝一个文件
	//打开文件
	//打开被读的文件
	FILE* pfRead = fopen("test1.txt", "r");
	if (pfRead == NULL)
	{
		perror("open file for read");
		return 1;
	}
	//打开要写的文件
	FILE* pfWrite = fopen("test2.txt", "w");
	if (pfWrite == NULL)
	{
		fclose(pfRead);
		pfRead = NULL;
		pfRead = NULL;
		perror("open file for write");
		return 1;
	}

	//拷贝
	int ch = 0;
	while ((ch=fgetc(pfRead)) != EOF)
	{
		fputc(ch,pfWrite);
	}

	//关闭文件
	fclose(pfRead);
	pfRead = NULL;
	fclose(pfWrite);
	pfWrite = NULL;
	return 0;
}

执行:

test1:起始文件

test2:目标文件

c语言的文件操作到这里就写完了,如有不对的地方,欢迎大佬的指导,感谢您的来访!

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/601170.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何做好网站建设定制开发

随着互联网的发展&#xff0c;如今的网站建设技术越来越先进&#xff0c;所以在网站建设定制开发中就出现了很多的模版&#xff0c;如&#xff1a;企业类型、产品信息、品牌介绍等。当然网站建设定制开发不是说只要模版就行了&#xff0c;对于网站建设而言&#xff0c;模版只是…

【送书福利-第八期】《硅基物语.AI大爆炸: ChatGPT→AIGC→GPT-X→AGI进化→魔法时代→人类未来》

大家好&#xff0c;我是洲洲&#xff0c;欢迎关注&#xff0c;一个爱听周杰伦的程序员。关注公众号【程序员洲洲】即可获得10G学习资料、面试笔记、大厂独家学习体系路线等…还可以加入技术交流群欢迎大家在CSDN后台私信我&#xff01; 本文目录 一、前言二、内容介绍三、作者介…

如何进行网站建设定制开发

如今&#xff0c;由于互联网的迅速发展&#xff0c;市场竞争越来越激烈&#xff0c;企业想要在市场中保持竞争力&#xff0c;就必须要有自己的品牌形象。而网站建设则是品牌建设的重要组成部分&#xff0c;一个好的网站能够有效提升企业品牌形象&#xff0c;提高客户满意度和忠…

Linux LNMP(Linux NGINX MySQL PHP)

NGINX处理静态页面性能出色&#xff0c;但是动态页面几乎没有处理能力&#xff0c;比Apache还差 所以涉及动态页面的场合一般由PHP Python Java&#xff08;后缀php&#xff0c;py&#xff0c;jsp&#xff09;等处理 静态页面请求 客户端 -> nginx动态页面请求 …

【工具推荐】使用D3.js制作网页版网络拓扑图,可拖转可跳转链接

文章目录 一、有哪些工具可以生成带链接的网络拓扑图二、推荐使用D3.js三、写个 demo吧四、d3.js相关学习资料1.官方网站2.D3.js 教程3.D3.js 教程 一、有哪些工具可以生成带链接的网络拓扑图 有一些 JavaScript 库可以帮助你创建网络拓扑图&#xff0c;并且支持将每个节点作为…

chatgpt赋能python:Python函数相加:如何使用函数进行数学计算

Python函数相加&#xff1a;如何使用函数进行数学计算 在Python编程中&#xff0c;函数是一种非常有用的工具&#xff0c;可以将代码组织成可重复使用的块。函数可以接受输入并产生输出&#xff0c;也可以执行任何数量的操作。在本文中&#xff0c;我们将介绍如何使用Python函…

美创科技新一代 灾备一体化平台(DRCC v3.0)发布

随着数字化转型浪潮的迅速推进&#xff0c;关键基础设施的运行安全和业务连续性保证成为数字化建设的基石。 云计算时代带来的资产复杂性和灾备技术多态性&#xff0c;给灾备能力建设、灾备资源高效利用和日常灾备运营提出了新挑战。灾备建设如何“简单又弹性”、灾备运营如何“…

Cloudflare 的 Kafka 故事:在处理 1 万亿条消息的过程中吸取的经验教训

关键要点 Cloudflare在处理大量数据时使用Kafka集群&#xff0c;开发了一个通用的消息总线集群&#xff0c;以解耦团队、有效扩展和处理数万亿条消息。 为了解决事件驱动系统中无结构通信的问题&#xff0c;应建立一个强有力的契约&#xff1a;跨平台数据格式Protobuf帮助Cl…

【教程】路由器自动定时登录校园网

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhang.cn] 目录 前景提要 Python脚本 Shell脚本(推荐) 路由器挂机 实现效果 前景提要 小米路由R4A千兆版安装breedOpenWRT教程以及救砖&#xff08;全脚本无需硬改&#xff09;【教程】保姆级红米AX6000刷UBoot和OpenW…

【Shiro】使用org.crazycake依赖的ShiroConfig

前言 整个Shiro专题中&#xff0c;这个部分是最早需要开始看的&#xff0c;主要先了解ShiroConfig都有哪些东西&#xff1b;由于这个项目使用的redis依赖是org.crazycake的shiro-redis&#xff0c;与我后面所用的不同&#xff0c;所以该部分只是简单的梳理了一下。 PS&#xf…

Hadoop高可用集群

HA高可用集群 HA介绍 什么是HA HA: High Availability&#xff0c;高可用集群&#xff0c;指的是集群7*24小时不间断服务。 为什么需要HA 在HDFS中&#xff0c;有NameNode、DataNode和SecondaryNameNode角色的分布&#xff0c;客户端所有的操作都是要与NameNode交互的&#xff…

PG数据库提示: FATAL: sorry, too many clients already

目录 场景&#xff1a; idea启动提示如下错误 翻译&#xff1a; 连接数相关查询&#xff1a; 原因分析&#xff1a; 解决方法&#xff1a; 场景&#xff1a; idea启动提示如下错误 org.postgresql.util.PSQLException: FATAL: sorry, too many clients alreadyat org.pos…

运维小白必学篇之基础篇第四集:vim文本编辑器实验

vim文本编辑器实验 1、创建a.txt文件&#xff0c;并复制到/tmp/file/目录下 2、创建1.txt文件的软链接文件11.txt 3、移动a.txt文件到/mnt目录下并改名为abc.txt 4、创建d1、d2目录&#xff0c;并在d1目录中创建文件a1、a2 5、删除d1目录和d2目录 6、查看/etc/man_db.conf文件的…

DPCNN:深度金字塔 CNN 文本分类网络

DPCNN&#xff08;Deep Pyramid CNN&#xff09;&#xff0c;是2017年腾讯AI-Lab提出的一种用于文本分类的网络&#xff0c;可以称之为"深度金字塔卷积神经网络"。 论文&#xff1a;Deep Pyramid Convolutional Neural Networks for Text Categorization 在之前的博…

运维小白必学篇之基础篇第五集:用户和组实验

用户和组实验 实验者&#xff1a;胡 阳 1、创建u1用户&#xff0c;指定UID为1050&#xff0c;并为该用户设置密码 2、创建u2用户&#xff0c;设置其不能登录操作系统 3、创建u3用户&#xff0c;指定其家目录为/mnt/u3 4、将u1用户改名为s1 5、创建用户u1&#xff0c;指定其UID…

为什么企业都需要一个ERP系统?对公司管理和业务增长都太重要了

什么是ERP系统&#xff1f; ERP&#xff08;Enterprise Resource Planning&#xff0c;企业资源计划&#xff09;系统是一种应用软件&#xff0c;它通过集成管理企业内部系统和外部合作伙伴系统的各种业务过程&#xff0c;来实现企业资源的最优化配置和利用。ERP系统涵盖了企业…

VMware vSphere 8.0 Update 1a 正式版发布 - 企业级工作负载平台

VMware vSphere 8.0 Update 1a 正式版发布 - 企业级工作负载平台 ESXi 8.0 U1 & vCenter Server 8.0 U1 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-vsphere-8-u1/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;sy…

基于java SpringBoot和Vue uniapp的校园信息交流小程序

随着信息社会的网络化和计算机科学的广泛普及和迅速普及应用&#xff0c;具有综合智能的我国校园信息教育网络已成为推动中小学科学教育及其实践科学发展的信息技术手段。迅速推进了信息化改革&#xff0c;改善了高校信息交流的网络环境&#xff0c;提高了信息教育平台的管理水…

利用云服务器搭建云盘(搭建自己的在线存储可上传下载可共享)

Docker部署seafile 背景 由于学校最近有一个需求&#xff0c;搭建一个可供老师使用的在线存储&#xff0c;最后我自己就尝试这搭建。这过程中也出现了不少问题&#xff0c;下面我会说明&#xff01;&#xff01;&#xff01; 准备 需要一台云服务器&#xff08;如果你本地有…

chatgpt赋能python:Python写POC:提高网络安全攻防技能的利器

Python写POC&#xff1a;提高网络安全攻防技能的利器 随着信息化进程的发展&#xff0c;计算机网络的应用越来越广泛&#xff0c;网络安全问题也日益突出。针对网络安全问题的POC&#xff08;Proof Of Concept&#xff0c;概念验证代码&#xff09;作为一种低成本的、快速验证…