Java中IO的高级操作

目录

缓冲流

缓冲字节输入流:

缓冲字节输出流:

缓冲字符输入流:

缓冲字符输出流:

转换流

转换流字符输入:

转换流字符输出:

练习案例:

打印流

字节打印流:

字符打印流:

数据流

数据输入流:

数据输出流:

序列化流(对象流)

对象输入流:

输入多个对象:

对象输出流:

IO框架

常用方法:

FileUtils:

IOUtils:


缓冲流

缓冲字节输入流:

读数据时:它先用原始字节输入流一次性读取8KB的数据存入缓冲流内部的数组中(ps: 先一次多囤点货),再从8KB的字节数组中读取一个字节或者多个字节(把消耗屯的货)。

案例:

BufferedInputStream bufferedInputStream = new BufferedInputStream(FileInputStream fis);

获取字节缓冲输入流对象。

sif:字节输入流对象,用来获取文件的位置。

package com.zsh.day2.字节缓冲流;

import java.io.*;

/**
 * 字节缓冲输入流
 */
public class BufferedInputStreamDemo {
    public static void main(String[] args) {
        try (
                // 获取字节缓冲输入流对象
                BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream("abc\\1.txt"));
        ) {
            // 缓冲字节流:循环读取文件中的所有内容
            // 读取文件中的内容
            byte[] buf = new byte[1024 * 8];
            // 每次读取的字节数量
            int len;
            // 循环读取文件中的所有内容
            while ((len = bufferedInputStream.read(buf)) != -1) {
                // 输出读到的内容
                System.out.println(new String(buf));
            }
        }catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

缓冲字节输出流:

写数据时: 它是先把数据写到缓冲流内部的8BK的数组中(ps: 先攒一车货),等数组存满了,再通过原始的字节输出流,一次性写到目标文件中去(把囤好的货,一次性运走)。

案例:

BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(FileOutputStream() fos);

获取字节缓冲流输出对象。

fos:用来设置字节缓冲流输出后保存文件的路径地址。

package com.zsh.day2.字节缓冲流;

import java.io.*;

/**
 * 字节缓冲输出流
 */
public class BufferedOutputStreamDemo {
    public static void main(String[] args) {
        try (
                // 获取字节缓冲输出流对象
                BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(new FileOutputStream("abc\\1.txt",true));
        ) {
            // 定义写入内容
            byte[] buf = new byte[]{99,100};
            // 写入
            bufferedOutputStream.write(buf);
        }catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

缓冲字符输入流:

BufferedReader读数据时:它先原始字符输入流一次性读取8KB的数据存入缓冲流内部的数组中(ps: 先一次多囤点货),再从8KB的字符数组中读取一个字符或者多个字符(把消耗屯的货)。

案例:

BufferedReader bufferedReader = new BufferedReader(FileReader(String str) fr);

获取字符输入流对象。

fr:字符输入流对象,用来获取文件的位置。

int ch = bufferedReader.read();

每次读取一个字符,返回int,没有数据返回-1。

String line = bufferedReader.readLine()

每次读取一行字符,返回String,没有数据返回null。

package com.zsh.day2.字符缓冲流;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;

/**
 * 字符缓冲输入流
 */
public class BufferedReaderDemo {
    public static void main(String[] args) {
        // 获取字符缓冲输入流对象
        try (
                BufferedReader bufferedReader = new BufferedReader(new FileReader("abc\\1.txt"));
        ) {
            // 每次读一个字符
            int ch = bufferedReader.read();
            System.out.println((char) ch);

            // 定义字符串接收读到的数据
            String line;
            // 循环读取全部内容,每次读一行,不读到返回null
            while ((line = bufferedReader.readLine()) != null) {
                System.out.println(line);
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

缓冲字符输出流:

BufferedWriter写数据时: 它是先把数据写到字符缓冲流内部的8BK的数组中(ps: 先攒一车货),等数组存满了,再通过原始的字符输出流,一次性写到目标文件中去(把囤好的货,一次性运走)。如下图所示

案例:

BufferedWriter bufferedWriter = new BufferedWriter(FileWriter fw);

获取字符输出流对象

fw:用来设置字节缓冲流输出后保存文件的路径地址。

bufferedWriter.write(String str);

写入字符的方法。

bufferedWriter.newLine();

换行方法。

package com.zsh.day2.字符缓冲流;

import java.io.*;

/**
 * 缓冲字符输出流
 */
public class BufferWriterDemo {
    public static void main(String[] args) {
        try (
                // 获取缓冲字符输出流对象
                BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter("abc\\FileWriter3.txt"));
        ) {
            // 写入字符
            bufferedWriter.write("你好!");

            // 换行
            bufferedWriter.newLine();

            // 写入字符
            bufferedWriter.write("你也好!");
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

转换流

FileReader默认只能读取UTF-8编码格式的文件。如果使用FileReader读取GBK格式的文件,可能存在乱码,因为FileReader它遇到汉字默认是按照3个字节来读取的,而GBK格式的文件一个汉字是占2个字节,这样就会导致乱码。

Java给我们提供了另外两种流InputStreamReader,OutputStreamWriter,这两个流我们把它叫做转换流。它们可以将字节流转换为字符流,并且可以指定编码方案。

转换流字符输入:

InputStreamReader类

案例:

InputStreamReader inputStreamReader = new InputStreamReader(FileInputStream fis,String str);

获取字符转换流输入对象。

fis:获取读取文件的地址路径。

str:字符串,用来定义读取文件的规则,如:utf-8、gbk等。会按照指定编码格式读取文件内容。

package com.zsh.day2.字符转换流;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;

/**
 * 字符输入转换流
 */
public class InputStreamReaderDemo {
    public static void main(String[] args) {
        // 获取字符输入转换流对象
        try (
                InputStreamReader inputStreamReader = new InputStreamReader(new FileInputStream("abc\\gbk.txt"),"gbk");
        ) {
            // 数组接收读取内容
            char[] buf = new char[2];
            // 读取文件中的内容
            int len;
            // 循环读取文件内容
            while ((len = inputStreamReader.read(buf)) != -1) {
                System.out.println(new String(buf));
            }

        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

转换流字符输出:

OutputStreamWriter类

案例:

OutputStreamWriter outputStreamWriter = new OutputStreamWriter(new FileOutputStream(String str,boolean append),String str2);

获取字符转换流输出对象

str:文件写出保存路径。

append:是否追加内容,默认false直接覆盖。

str2:写出文件的编码格式,如utf-8、gbk等。

BufferedWriter bufferedWriter = new BufferedWriter(outputStreamWriter);

缓冲字符流对象,可以将转换流包装进缓冲流对象中。

package com.zsh.day2.字符转换流;

import java.io.*;

/**
 * 字符输出转换流
 */
public class OutPutStreamWriterDemo {
    public static void main(String[] args) {
        try (
                // 获取字符输出转换流对象
                OutputStreamWriter outputStreamWriter = new OutputStreamWriter(new FileOutputStream("abc\\gbk2.txt",true),"gbk");
                // 获取字符缓冲流对象
                BufferedWriter bufferedWriter = new BufferedWriter(outputStreamWriter);
        ) {
            // 写入内容,写入的编码格式为gbk
            bufferedWriter.write("这段文字的编码格式是gbk");

            // 换行
            bufferedWriter.newLine();

            // 写入内容,写入的编码格式为gbk
            bufferedWriter.write("会则不难,难则不会,哈哈哈哈!!!");
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

练习案例:

将gbk文件读取出来,放到utf-8文件中

package com.zsh.day2.字符转换流;

import java.io.*;

/**
 * 将gbk文件读取出来,放到utf-8文件中
 */
public class Demo {
    public static void main(String[] args) {
        try (
                // 获取输入转换流对象(当前读取格式为gbk)
                InputStreamReader inputStreamReader = new InputStreamReader(new FileInputStream("abc\\gbk2.txt"), "gbk");
                // 获取缓存流读对象
                BufferedReader bufferedReader = new BufferedReader(inputStreamReader);

                // 获取输出转换流对象(当前写入格式为utf-8)
                OutputStreamWriter outputStreamWriter = new OutputStreamWriter(new FileOutputStream("abc\\gbk3.txt",true),"utf-8");
                // 获取输入缓存流对象
                BufferedWriter bufferedWriter = new BufferedWriter(outputStreamWriter);
        ) {
            // 循环读取一行
            String line;
            while ((line = bufferedReader.readLine()) != null){
                System.out.println(line);
                // 把读到的数据写入到新文件中
                bufferedWriter.write(line);
                // 换行
                bufferedWriter.newLine();
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

打印流

打印流,这里所说的打印其实就是写数据的意思,它和普通的write方法写数据还不太一样,一般会使用打印流特有的方法叫print(数据)或者println(数据),它打印啥就输出啥。

打印流有两个,一个是字节打印流PrintStream,一个是字符打印流PrintWriter,如下图所示

字节打印流:

PrintStream类

案例:

PrintStream printStream = new PrintStream(String str);

获取字节打印流对象。

str:用来设置字节打印流输出后保存文件的路径地址。

printStream.println(10);

打印并换行(打印什么文件中就显示什么)。

printStream.write(99);

写入字节到文件(写入之后的内容会按照编码格式转换)。

package com.zsh.day2.字节打印流;

import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.PrintStream;

/**
 * 字节打印流
 */
public class PrintStreamDemo {
    public static void main(String[] args) {
        try (
                // 获取字节打印流对象
                PrintStream printStream = new PrintStream("abc\\BytePrint.txt");
        ) {
            // 打印字节到文件(打印什么文件中就显示什么)
            printStream.println(10);
            // 打印字节到文件
            printStream.print("这是一句话");
            // 打印字节到文件
            printStream.println("!!!");

            // 写入字节到文件(写入之后的内容会按照编码格式转换)
            printStream.write(99);
            // 换行
            printStream.write("\t\n".getBytes());
            // 写入字节到文件
            byte[] buf = new byte[]{100,101,102,103};
            printStream.write(buf);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

字符打印流:

PrintWriter类

案例:

PrintWriter printWriter = new PrintWriter(String str);

获取字符打印流对象。

str:用来设置字符打印流输出后保存文件的路径地址。

printWriter.println(10);

打印并换行(打印什么文件中就显示什么)。

printWriter.write(99);

写入字节到文件(写入之后的内容会按照编码格式转换)。

package com.zsh.day2.字符打印流;

import java.io.FileNotFoundException;
import java.io.PrintWriter;

/**
 * 字符打印流
 */
public class PrintWriterDemo {
    public static void main(String[] args) {
        try (
                // 获取字符打印流对象
                PrintWriter printWriter = new PrintWriter("abc\\BytePrint2.txt");
        ){
            // 打印字节到文件(打印什么文件中就显示什么)
            printWriter.println(10);
            // 打印字节到文件
            printWriter.print("这是一句话");
            // 打印字节到文件
            printWriter.println("!!!");

            // 写入字节到文件(写入之后的内容会按照编码格式转换)
            printWriter.write(99);
            // 换行
            printWriter.write("\t\n");
        } catch (FileNotFoundException e) {
            throw new RuntimeException(e);
        }
    }
}

数据流

把数据和数据的类型一并写到文件中去,读取的时候也将数据和数据类型一并读出来。这就可以用到数据流,有两个DataInputStream和DataOutputStream.

数据输入流:

DataInputStream类

读取时候,文件里面存储的什么类型的值,就需要用对应类型去读。

案例:

DataInputStream dataInputStream = new DataInputStream(FileInputStream fis);

获取数据输入流对象。

fis:获取读取文件的地址路径。

int i = dataInputStream.readInt();

读取文件中的int类型值

double d = dataInputStream.readDouble();

读取文件中的double类型值

boolean b = dataInputStream.readBoolean();

读取文件中的boolean类型值

String rs = dataInputStream.readUTF();

读取文件中的utf-8类型值

package com.zsh.day2.数据输入流;

import java.io.*;

/**
 * 数据输入流
 */
public class DateInputStreamDemo {
    public static void main(String[] args) {
        try (
                // 创建数据输入流对象
                DataInputStream dataInputStream = new DataInputStream(new FileInputStream("abc\\io-out.txt"));
        ) {
            int i = dataInputStream.readInt();
            System.out.println(i);

            double d = dataInputStream.readDouble();
            System.out.println(d);

            boolean b = dataInputStream.readBoolean();
            System.out.println(b);

            String rs = dataInputStream.readUTF();
            System.out.println(rs);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

数据输出流:

DataOutputStream类

案例:

DataOutputStream dataOutputStream = new DataOutputStream(FileOutputStream fos);

获取数据输出流对象。

fos:用来设数据打印流输出后保存文件的路径地址。

dataOutputStream.writeInt(97);

写入int数据

dataOutputStream.writeDouble(99.5);

写入double数据

dataOutputStream.writeBoolean(true);

写入布尔数据

dataOutputStream.writeUTF("这是一段utf-8的数据内容");

写入utf-8数据

package com.zsh.day2.数据输出流;

import java.io.DataOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;

/**
 * 数据输出流
 */
public class DataOutputStreamDemo {
    public static void main(String[] args) {
        try (
                // 创建数据输出流对象
                DataOutputStream dataOutputStream = new DataOutputStream(new FileOutputStream("abc\\io-out.txt"));
        ){
            // 写入int数据
            dataOutputStream.writeInt(97);
            // 写入double数据
            dataOutputStream.writeDouble(99.5);
            // 写入布尔数据
            dataOutputStream.writeBoolean(true);
            // 写入utf-8数据
            dataOutputStream.writeUTF("这是一段utf-8的数据内容");
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

序列化流(对象流)

节流是以字节为单位来读写数据、字符流是按照字符为单位来读写数据、而对象流是以对象为单位来读写数据。也就是把对象当做一个整体,可以写一个对象到文件,也可以从文件中把对象读取出来。

对象输入流:

ObjectInputStream类

案例:

ObjectInputStream objectInputStream = new ObjectInputStream(FileInputStream fis);

获取对象输入流对象。

fis:获取读取文件的地址路径。

Object o = objectInputStream.readObject();

获取文件中的对象。反序列化

package com.zsh.day2.对象输入流;

import com.zsh.pojo.User;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.ObjectInputStream;

/**
 * 对象输入流
 */
public class ObjectInputStreamDemo {
    public static void main(String[] args) {
        try (
                // 获取对象输入流对象
                ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("abc\\object.txt"));
        ) {
            // 获取文件中的对象
            Object o = objectInputStream.readObject();
            User user = (User) o;
            // 输出
            System.out.println(user);
        } catch (IOException e) {
            throw new RuntimeException(e);
        } catch (ClassNotFoundException e) {
            throw new RuntimeException(e);
        }
    }
}

输入多个对象:

案例一:

把多个对象写入一个文件中,循环读取时条件可以设置为true,读取完之后会出现:EOFException异常表示文件读取完了,try/catch处理即可。

package com.zsh.day2.对象输入流;

import com.zsh.pojo.User;

import java.io.*;

/**
 * 把多个对象存入文件
 */
public class ObjectInputStreamAllDemo {
    public static void main(String[] args) {
        try (
                // 获取对象输出流对象
                ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("abc\\ObjectAll.txt"));
        ) {
            User user1 = new User("张三",20);
            User user2 = new User("李四",21);
            User user3 = new User("王五",22);
            // 把对象写入到文件
            objectOutputStream.writeObject(user1);
            objectOutputStream.writeObject(user2);
            objectOutputStream.writeObject(user3);
        } catch (FileNotFoundException e) {
            throw new RuntimeException(e);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }

        // 读取文件中的对象
        readTest();
    }

    /**
     * 读取文件中的对象
     */
    private static void readTest() {
        // 获取对象输入流对象
        try (
                ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("abc\\ObjectAll.txt"));
        ) {
            // 循环读取文件中的内容(当文件读取完时候,会出现:EOFException异常,表示文件读取完了)
            while (true) {
                // 读取文件中的对象
                Object o = objectInputStream.readObject();
                // 转换
                User user = (User) o;
                // 打印
                System.out.println(user);
            }
        } catch (EOFException e) {
            System.out.println("文件读取完了:" + e);
        } catch (IOException e) {
            System.out.println("文件读取异常:" + e);
        } catch (ClassNotFoundException e) {
            System.out.println("文件找不到:" + e);
        }
    }
}

案例二:

也可以把多个对象放到ArrayList中,在放到文件中,这样也可也存储多个对象。

package com.zsh.day2.对象输入流;

import com.zsh.pojo.User;

import java.io.*;
import java.util.ArrayList;

/**
 * 把多个对象存入文件
 */
public class ObjectInputStreamAllDemo {
    public static void main(String[] args) {
        try (
                // 获取对象输出流对象
                ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("abc\\ObjectAll.txt"));
        ) {
            // 创建对象
            User user1 = new User("张三",20);
            User user2 = new User("李四",21);
            User user3 = new User("王五",22);

            // 创建集合1
            ArrayList<User> list = new ArrayList<>();
            list.add(user1);
            list.add(user2);
            list.add(user3);
            // 创建集合2
            ArrayList<User> list2 = new ArrayList<>();
            list2.add(user1);
            list2.add(user2);
            list2.add(user3);

            // 把对象写入到文件
            objectOutputStream.writeObject(list);
            objectOutputStream.writeObject(list2);
        } catch (FileNotFoundException e) {
            throw new RuntimeException(e);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }

        // 读取文件中的对象
        readTest();
    }

    /**
     * 读取文件中的对象
     */
    private static void readTest() {
        // 获取对象输入流对象
        try (
                ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("abc\\ObjectAll.txt"));
        ) {
            // 循环读取文件中的内容(当文件读取完时候,会出现:EOFException异常,表示文件读取完了)
            while (true) {
                // 读取文件中的对象
                Object o = objectInputStream.readObject();
                // 转换
                ArrayList<User> list = (ArrayList<User>) o;
                // 打印
                System.out.println(list);
            }
        } catch (EOFException e) {
            System.out.println("文件读取完了:" + e);
        } catch (IOException e) {
            System.out.println("文件读取异常:" + e);
        } catch (ClassNotFoundException e) {
            System.out.println("文件找不到:" + e);
        }
    }
}

对象输出流:

ObjectOutputStraem类

案例:

创建对象,必须实现:Serializable接口,这是一个标记接口,证明对象可以被序列化。

package com.zsh.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Serializable {
    private String name;
    private Integer age;
}

ObjectOutputStream objectOutputStream = new ObjectOutputStream(FileOutputStream fos);

获取对象输出流对象。

fos:用来设置对象流输出后保存文件的路径地址。

objectOutputStream.writeObject(Object o);

o:要写到文件中的对象。

package com.zsh.day2.对象输出流;

import com.zsh.pojo.User;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;

/**
 * 对象输出流
 */
public class ObjectOutputStreamDemo {
    public static void main(String[] args) {
        try (
                // 获取对象输出流
                ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("abc\\object.txt"));
        ) {
            // 创建对象
            User user = new User("张三",20);
            // 将对象写入文件(写入文件的对象必须实现:Serializable接口,这是一个标记接口,证明对象可以被序列化)
            objectOutputStream.writeObject(user);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

IO框架

在maven中引入依赖

<!-- io流框架 -->
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.11.0</version>
</dependency>x

常用方法:

FileUtils:

FileUtils:直接操作文件。

FileUtils.copyFile(File f1,File f2);

复制文件。

f1:复制的文件路径。

f2:拷贝到的文件路径。

FileUtils.copyDirectory(File f1,File f2);

复制文件夹。

f1:复制的文件夹路径。

f2:拷贝到的文件夹路径。

FileUtils.deleteDirectory(File f);

删除文件夹。

f:删除的文件夹路径。

String str = FileUtils.readFileToString(File f,String str);

读数据。

f:要读取的文件路径。

str:读取的格式,如:utf-8、gbk等。

IOUtils:

IOUtils:通过流操作文件

IOUtils.copy(FileInputStream fis,FileOutputStream fos);

复制文件。

fis:要复制的文件路径。

fos:复制后要保存的路径

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Matlab高光谱遥感

原文链接&#xff1a;Matlab高光谱遥感https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247623643&idx5&sne4557ed43728f851140b100f42286988&chksmfa8da23ccdfa2b2a4d795bf4087f672faaa7082d1f52e046616ab7bf196a6eef89ea553d06b1&token1392391660&…

ssm+jsp663数学课程评价系统的设计与开发

博主介绍&#xff1a;专注于Java&#xff08;springboot ssm 等开发框架&#xff09; vue .net php phython node.js uniapp 微信小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设&#xff0c;从业十五余年开发设计教学工作 ☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不…

openssl-ec-chn命令手册

openssl-ec命令处理EC&#xff08;Elliptic Curve&#xff0c;椭圆曲线&#xff09;密钥。使密钥可以在各种形式之间转换&#xff0c;并打印出其组件。注意&#xff1a;OpenSSL使用“SEC 1:椭圆曲线密码学&#xff08;Elliptic Curve Cryptography&#xff09;”中指定的私钥格…

(JVM)深入JAVA底层 JVM(Java 虚拟机)!带你认识JVM、程序计数器、JVM栈和方法栈还有堆内存!看看JAVA针对这些内存空间都做了什么吧!

1. 什么是JVM java 二进制字节码的运行环境&#xff0c;简称&#xff1a;java 虚拟机&#xff08;Java Virtual Machine&#xff09; 2. 好处是什么 一次编写&#xff0c;到处运行自动内存管理&#xff0c;GC垃圾回收功能数组下标越界检查多态… 3. jdk、jre、jvm 4. 学习J…

OLAP平台架构演化历程

OLAP平台架构演化历程 0 导读 随着大数据的持续发展及数字化转型的兴起&#xff0c;大数据OLAP分析需求越来越迫切&#xff0c;不论是大型互联网企业&#xff0c;还是中小型传统企业&#xff0c;都在积极探索及实践OLAP引擎选型及平台架构建设&#xff0c;大数据技术的蓬勃发展…

Kaggle入门指南(Kaggle竞赛)

文章目录 Kaggle 入门指南1. Kaggle 的功能概述1.1 竞赛1.2 数据集1.3 学习与教程1.4 社区 2. 注册与设置2.1 创建账户2.2 完善个人资料 3. 探索数据集3.1 查找数据集3.2 下载数据集示例代码&#xff1a;加载数据集 3.3 数据预处理示例代码&#xff1a;数据预处理 4. 参与竞赛4…

docker 可用镜像服务地址(2024.10.31亲测可用)

1.错误 Error response from daemon: Get “https://registry-1.docker.io/v2/” 原因&#xff1a;镜像服务器地址不可用。 2.可用地址 编辑daemon.json&#xff1a; vi /etc/docker/daemon.json内容修改如下&#xff1a; {"registry-mirrors": ["https://…

TortoiseSVN小乌龟下载安装(Windows11)

目录 TortoiseSVN 1.14.7工具下载安装 TortoiseSVN 1.14.7 工具 系统&#xff1a;Windows 11 下载 官网&#xff1a;https://tortoisesvn.subversion.org.cn/downloads.html如图选 TortoiseSVN 1.14.7 - 64 位 下载完成 安装 打开 next&#xff0c;next Browse&#xf…

CAD图纸防泄密|哪些措施可以加密公司图纸?五个宝藏方法分享,2024必读!

在工程设计领域&#xff0c;CAD图纸作为企业的核心资产&#xff0c;其安全性至关重要。一旦图纸泄露&#xff0c;不仅可能给企业带来重大的经济损失&#xff0c;还可能损害企业的声誉和竞争力。 那么&#xff0c;怎么实现CAD图纸防泄密呢&#xff1f; 以下是五个CAD图纸防泄密…

Centos7安装最新版EMQX(v5.8.1)

引言 由于从centos停止维护&#xff0c;导致yum源不可用&#xff0c;好多方法安装都有问题&#xff0c;各种缺依赖&#xff1b;其实最简单就是换操作系统&#xff0c;Ubuntu&#xff0c;centos停止维护之后我们现在服务器基本上都是Ubuntu;而我的环境又不想再折腾&#xff0c;…

网络应用技术 实验二:交换机VLAN 应用(华为ensp)

目录 一、实验简介 二、实验目的 三、实验需求 四、实验拓扑 五、实验任务及要求 1、任务 1&#xff1a;在交换机上创建VLAN 并测试通信 2、任务 2&#xff1a;路由交换机实现VLAN 之间通信 六、实验步骤 1、完成任务 1 2、完成任务 2 一、实验简介 在交换机上配置 VLAN&#x…

数学期望和联合概率密度

数学期望的定义 数学期望是描述随机变量平均趋势的一个重要统计量。根据随机变量的类型&#xff08;离散或连续&#xff09;&#xff0c;数学期望的定义有所不同。 离散型随机变量的数学期望&#xff1a; 若离散型随机变量 X X X取值为 x 1 , x 2 , … , x n , … x_1,x_2,\do…

Python基础学习(十)面向对象编程(基础)

代码获取&#xff1a;https://github.com/qingxuly/hsp_python_course 完结版&#xff1a;Python基础学习&#xff08;完结版&#xff09; 面向对象编程&#xff08;基础&#xff09; 类与对象 类与实例的关系 类与实例的关系示意图 快速入门—面向对象的方式解决养猫问题 …

.bixi勒索病毒来袭:如何防止文件加密与数据丢失?

导言 在网络威胁剧烈的今天&#xff0c;勒索病毒已成为企业和个人面临的重大安全挑战&#xff0c;其中虫洞勒索病毒习得高强度的加密手段和急剧传播的特性引起关注。一旦感染&#xff0c;就会加密关键数据并索要赎金&#xff0c;导致数据无法访问并带来巨大的财务损失。更为严…

OpenCV基础02_图像预处理

图像预处理 在计算机视觉和图像处理领域&#xff0c;图像预处理是一个重要的步骤&#xff0c;它能够提高后续处理&#xff08;如特征提取、目标检测等&#xff09;的准确性和效率。 OpenCV 提供了许多图像预处理的函数和方法&#xff0c;一些常见的图像预处理操作&#xff1a…

ctf文件上传题小总结与记录

解题思路&#xff1a;先看中间件&#xff0c;文件上传点&#xff08;字典扫描&#xff0c;会员中心&#xff09;&#xff0c;绕过/验证&#xff08;黑名单&#xff0c;白名单&#xff09;&#xff0c;解析漏洞&#xff0c;cms&#xff0c;编辑器&#xff0c;最新cve 文件上传漏…

安全成为大模型的核心;大模型安全的途径:大模型对齐

目录 安全成为大模型的核心 大模型安全的途径:大模型对齐 人类反馈强化学习(RLHF) 直接偏好优化(DPO) 安全成为大模型的核心 大模型安全的途径:大模型对齐 大模型对齐技术(Alignment Techniques for Large Language Models)是确保大规模语言模型(例如GPT-4)的输…

基于知识引导提示的因果概念提取(论文复现)

基于知识引导提示的因果概念提取(论文复现) 本文所涉及所有资源均在传知代码平台可获取 文章目录 基于知识引导提示的因果概念提取(论文复现)论文概述论文方法提示构造器获取典型概念集聚类典型概念构建训练数据训练主题分类器概念提取器输入构造指针网络置信度评分训练损失…

Rust的enum枚举的强大用法

在Rust中&#xff0c;enum&#xff08;枚举&#xff09;是一种非常强大的类型&#xff0c;它可以包含多个变体&#xff08;variants&#xff09;&#xff0c;每个变体可以是不同的类型&#xff0c;包括复杂类型。这使得enum在Rust中不仅用于表示简单的状态或选项集合&#xff0…

vue常用的修饰符有哪些

1、修饰符是什么 在Vue 中&#xff0c;修饰符处理了许多 DOM 事件的细节&#xff0c;让我们不再需要花大量的时间去处理这些烦恼的事情&#xff0c;而能有更多的精力专注于程序的逻辑处理 vue中修饰符分为以下五种 汇总修饰符说明表单lazy光标离开标签的时候&#xff0c;才会…