Go标准库之读写文件(File)

创建一个空文件
package main

import (
"log"
"os"
) func main() {
file, err := os.Create("empty.txt")
if err != nil {
log.Fatal("create file err", err)
}
log.Println(file)
file.Close()
}
获取文件的信息
package main

import (
"fmt"
"log"
"os"
) func main() {
fileInfo, err := os.Stat("main.go")
if err != nil {
log.Fatal(err)
}
fmt.Println("File Name:", fileInfo.Name())
fmt.Println("Size in bytes:", fileInfo.Size())
fmt.Println("Permissions:", fileInfo.Mode())
fmt.Println("Last modified:", fileInfo.ModTime())
fmt.Println("Is Directory:", fileInfo.IsDir())
fmt.Printf("System interface type:%T\v\n", fileInfo.Sys())
fmt.Printf("System info:%+v\n\n", fileInfo.Sys())
}
重命名和移动文件
package main

import (
"log"
"os"
) func main() {
originalPath := "empty.txt"
newPath := "test.txt"
err := os.Rename(originalPath, newPath)
if err != nil {
log.Fatal(err)
}
}
删除文件
package main

import (
"log"
"os"
) func main() {
err := os.Remove("empty.txt")
if err != nil {
log.Fatal(err)
}
}
打开关闭文件
package main

import (
"log"
"os"
) func main() {
//简单的打开文件
file, err := os.Open("test.txt")
if err != nil {
log.Fatal(err)
}
file.Close() file, err = os.OpenFile("test.txt", os.O_APPEND, 0666)
if err != nil {
log.Fatal(err)
}
file.Close()
}
打开文件的一些其他的操作
os.O_RDONLY     //只读
os.O_WRONLY //只写
os.O_RDWR //读写文件
os.O_APPEND //追加文件
os.O_CREATE //不存在时创建文件
os.O_TRUNC //打开时截断文件
检查文件是否存在
package main

import (
"log"
"os"
) var (
fileInfo *os.FileInfo
err error
) func main() {
fileInfo, err := os.Stat("test.txt")
if err != nil {
if os.IsNotExist(err) {
log.Fatal("File does not exist.")
}
}
log.Println("File does exist.File information:")
log.Println(fileInfo)
}
检查文件的读写权限
package main

import (
"log"
"os"
) func main() {
file, err := os.OpenFile("test.txt", os.O_WRONLY, 0666)
if err != nil {
if os.IsPermission(err) {
log.Println("Error:Write permission denied.")
}
}
file.Close()
file, err = os.OpenFile("test.txt", os.O_RDONLY, 0666)
if err != nil {
if os.IsPermission(err) {
log.Println("Error:Read permission denied.")
}
}
file.Close()
}
改变文件的权限、所有权和时间戳
package main

import (
"log"
"os"
"time"
) func main() {
//改变权限
err := os.Chmod("test.txt", 0777)
if err != nil {
log.Println(err)
} //改变所有权 适用于linux, windows不支持
err = os.Chown("test.txt", os.Getuid(), os.Getegid())
if err != nil {
log.Println(err)
} //改变时间戳
twoDaysFromNow := time.Now().Add(48 * time.Hour)
lastAccessTime := twoDaysFromNow
lastModifyTime := twoDaysFromNow
err = os.Chtimes("test.txt", lastAccessTime, lastModifyTime)
if err != nil {
log.Println(err)
}
}
复制文件
package main

import (
"io"
"log"
"os"
) func main() {
//打开原文件
originalFile, err := os.Open("test.txt")
if err != nil {
log.Fatal(err)
}
defer originalFile.Close() //创建新文件
newFile, err := os.Create("test_copy.txt")
if err != nil {
log.Fatal(err)
}
defer newFile.Close() //文件复制
bytes, err := io.Copy(newFile, originalFile)
if err != nil {
log.Fatal(err)
}
log.Printf("Copied %d bytes.", bytes) err = newFile.Sync()
if err != nil {
log.Fatal(err)
}
}
移动位置
package main

import (
"fmt"
"log"
"os"
) func main() {
file, err := os.Open("test.txt")
if err != nil {
log.Fatal(err)
}
defer file.Close()
var offset int64 = 5 var whence int = 0
newPos, err := file.Seek(offset, whence)
if err != nil {
log.Fatal(err)
}
fmt.Println("Just moved to 5:", newPos) newPos, err = file.Seek(-2, 1)
if err != nil {
log.Fatal(err)
}
fmt.Println("Just moved back two:", newPos) currentPos, err := file.Seek(0, 1)
fmt.Println("current pos:", currentPos) newPos, err = file.Seek(0, 0)
if err != nil {
log.Fatal(err)
}
fmt.Println("position after seek 0,0:", newPos)
}
向文件中写入字节
package main

import (
"log"
"os"
) func main() {
file, err := os.OpenFile("test.txt", os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0666)
if err != nil {
log.Fatal(err)
}
defer file.Close() bytes := []byte("测试写入功能!")
bw, err := file.Write(bytes)
if err != nil {
log.Fatal(err)
}
log.Printf("Wrote %d bytes.\n", bw)
}
快速写入文件
package main import (
"io/ioutil"
"log"
) func main() {
err := ioutil.WriteFile("test.text", []byte("测试快速写入功能!"), 0666)
if err != nil {
log.Fatal(err)
}
}
在写入时使用缓存
package main

import (
"bufio"
"log"
"os"
) func main() {
file, err := os.OpenFile("test.txt", os.O_WRONLY, 0666)
if err != nil {
log.Fatal(err)
}
defer file.Close() buffer := bufio.NewWriter(file)
bw, err := buffer.Write([]byte{65, 66, 67})
if err != nil {
log.Fatal(err)
}
log.Printf("Bytes written:%d\n", bw)
bw, err = buffer.WriteString("\n写入字符串")
if err != nil {
log.Fatal(err)
}
log.Printf("Bytes written: %d\n", bw) unFlushedBuffer := buffer.Buffered()
log.Printf("Bytes buffered:%d\n", unFlushedBuffer) ba := buffer.Available()
log.Printf("Available buffer: %d\n", ba) buffer.Flush() buffer.Reset(buffer) ba = buffer.Available()
log.Printf("Availabled buffer:%d\n", ba) buffer = bufio.NewWriterSize(buffer, 8000)
ba = buffer.Available()
if err != nil {
log.Fatal(err)
}
log.Printf("Available buffer: %d\n", ba) }
从文件中读取n个字节
package main

import (
"log"
"os"
) func main() {
file, err := os.Open("test.txt")
if err != nil {
log.Fatal(err)
}
defer file.Close()
//从文件中读取16个字节
bytes := make([]byte, 16)
br, err := file.Read(bytes)
if err != nil {
log.Fatal(err)
} log.Printf("number of bytes read: %d\n", br)
log.Printf("Data read: %s\n", bytes)
}
读取文件中全部内容
data, err := ioutil.ReadAll(file)
快速读取文件到内存中
package main

import (
"log"
"io/ioutil"
) func main() {
data, err := ioutil.ReadFile("test.txt")
if err != nil {
log.Fatal(err)
} log.Printf("Data read: %s\n", data)
}

Go标准库之读写文件(File)的更多相关文章

  1. 用 #include “filename.h” 格式来引用非标准库的头文件

    用 #include “filename.h” 格式来引用非标准库的头文件(编译器将 从用户的工作目录开始搜索) #include <iostream> /* run this progr ...

  2. 用 #include <filename.h> 格式来引用标准库的头文件

    用 #include <filename.h> 格式来引用标准库的头文件(编译器将从 标准库目录开始搜索). #include <iostream> /* run this p ...

  3. c/c++标准库中的文件操作总结

    1 stdio.h是c标准库中的标准输入输出库 2 在c++中调用的方法 直接调用即可,但是最好在函数名前面加上::,以示区分类的内部函数和c标准库函数. 3 c标准输入输出库的使用 3.1 核心结构 ...

  4. C++标准库实现WAV文件读写

    在上一篇文章RIFF和WAVE音频文件格式中对WAV的文件格式做了介绍,本文将使用标准C++库实现对数据为PCM格式的WAV文件的读写操作,只使用标准C++库函数,不依赖于其他的库. WAV文件结构 ...

  5. Python 标准库 csv —— csv 文件的读写

    csv 文件,逗号分割文件. 0. 读取 csv 到 list from csv import reader def load_csv(csvfile): dataset = [] with open ...

  6. 标准I/O读写文件

    一.函数原型 1.FILE *fopen(const char *path, const char *mode); path:要打开文件路径及文件名: mode:  r 打开只读文件,该文件必须存在. ...

  7. python --标准库 路径与文件 (os.path包, glob包)

    os.path包 os.path包主要是处理路径字符串,提取出有用信息. #coding:utf-8 import os.path path = 'D:\\Python7\\test\\data.tx ...

  8. C++标准库头文件找不到的问题

    当你写C++程序时,在头文件中包含C++标准库的头文件,比如#include <string>,而编译器提示你找不到头文件! 原因就是你的实现源文件扩展名是".c"而不 ...

  9. C++primer第三章标准库类型

    除第二章介绍的基本数据类型外,C++ 还定义了一个内容丰富的抽象数据类型标准库. 本章将介绍标准库中的 vector.string 和 bitset 类型. string 类型支持长度可变的字符串 v ...

随机推荐

  1. 微信H5支付 遇到坑的一些解决方法

    解决办法 1. 商家参数格式有误,请联系商家解决 a.对于前后端分离的开发模式 前端发起请求 服务端请求微信h5支付统一下单接口 返回参数mweb_url 给前端 然后前端调起微信h5支付 b.注意的 ...

  2. C程序的编译与链接

    编译器驱动程序 编译器驱动程序可以在用户需要时调用语言预处理器.编译器.汇编器和链接器. 例如使用GNU编译系统,我们需要使用如下命令来调用GCC驱动程序: gcc -o main main.c 编译 ...

  3. 移动端的1px边框问题

    最近在做一个移动端项目,涉及到1像素问题 其实质就是移动端的css里写1px,看起来比1px粗,这就是物理像素和逻辑像素的区别.物理像素和逻辑像素之间存在一个比例关系,在Javascript中可以用w ...

  4. 定时任务APScheduler

    安装 APScheduler $ pip install apscheduler 快速开始 from apscheduler.schedulers.blocking import BlockingSc ...

  5. LAB2

    任务1: 效果:HelloWorld 好像完全按视频做就行了 学会了:把glassfish改好了,能跑 没学会:视频里的解说不懂在干嘛,得再看看 任务2 效果:intersetingpicture要求 ...

  6. cmp指令

    cmp是比较指令,cmp的功能相当于减法指令,只是不保存结果.cmp指令执行后,将对标志寄存器产生影响.其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果. cmp指令格式: cmp 操作对象 ...

  7. Pycharm中选择Python解释器

    新建项目后,有时候Pycharm找不到Python解释器,如果找不到的话,就会报错.报错信息: No python interpreter configured for the project 找到P ...

  8. 互联网公司的面试官是如何360°无死角考察候选人的?[z]

    [z]https://juejin.im/post/5c0e47ebf265da614e2be9a7 一.写在前面 最近收到不少读者反馈,说自己在应聘一些中大型互联网公司的Java工程师岗位时遇到了不 ...

  9. sqlserver 组内排序

    关键词 partition(分区函数[pɑː'tɪʃ(ə)n])  by 参考: https://www.cnblogs.com/sanlang/archive/2009/03/24/1420360. ...

  10. HTML中关于class内容空格多类名的问题详解

    之所以想谈谈这个,不明所以.所以转载下来方便自己看看. 问:像 class="info fl" 这种class定义是何意思? 答:这里的空格隔开后,它们所代表的是两个类名,分别为i ...