Go标准库之读写文件(File)
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)的更多相关文章
- 用 #include “filename.h” 格式来引用非标准库的头文件
用 #include “filename.h” 格式来引用非标准库的头文件(编译器将 从用户的工作目录开始搜索) #include <iostream> /* run this progr ...
- 用 #include <filename.h> 格式来引用标准库的头文件
用 #include <filename.h> 格式来引用标准库的头文件(编译器将从 标准库目录开始搜索). #include <iostream> /* run this p ...
- c/c++标准库中的文件操作总结
1 stdio.h是c标准库中的标准输入输出库 2 在c++中调用的方法 直接调用即可,但是最好在函数名前面加上::,以示区分类的内部函数和c标准库函数. 3 c标准输入输出库的使用 3.1 核心结构 ...
- C++标准库实现WAV文件读写
在上一篇文章RIFF和WAVE音频文件格式中对WAV的文件格式做了介绍,本文将使用标准C++库实现对数据为PCM格式的WAV文件的读写操作,只使用标准C++库函数,不依赖于其他的库. WAV文件结构 ...
- Python 标准库 csv —— csv 文件的读写
csv 文件,逗号分割文件. 0. 读取 csv 到 list from csv import reader def load_csv(csvfile): dataset = [] with open ...
- 标准I/O读写文件
一.函数原型 1.FILE *fopen(const char *path, const char *mode); path:要打开文件路径及文件名: mode: r 打开只读文件,该文件必须存在. ...
- python --标准库 路径与文件 (os.path包, glob包)
os.path包 os.path包主要是处理路径字符串,提取出有用信息. #coding:utf-8 import os.path path = 'D:\\Python7\\test\\data.tx ...
- C++标准库头文件找不到的问题
当你写C++程序时,在头文件中包含C++标准库的头文件,比如#include <string>,而编译器提示你找不到头文件! 原因就是你的实现源文件扩展名是".c"而不 ...
- C++primer第三章标准库类型
除第二章介绍的基本数据类型外,C++ 还定义了一个内容丰富的抽象数据类型标准库. 本章将介绍标准库中的 vector.string 和 bitset 类型. string 类型支持长度可变的字符串 v ...
随机推荐
- Linux shell 信号继承
shell中,向进程发送信号多多通过ctrl键加上一些功能键来实现,这里是常见的Ctrl组合键及其意义: 组合键 信号类型 意义 Ctrl+C INT信号,即interrupt信号 停止运行当前的作业 ...
- IOC 和DI(转载)
IOC 是什么? Ioc—Inversion of Control,即“控制反转”,不是什么技术,而是一种设计思想.在Java开发中,Ioc意味着将你设计好的对象交给容器控制,而不是传统的在你的对象内 ...
- Java 基本类型和包装类型
讲基本类型和包装类型之前,首先要介绍,装箱和拆箱 装箱:基本类型转化为包装类型 拆箱:包装类型转化为拆箱类型 为什么要有包装类型?Java是面向对象的语言,Java中一切都是对象除了基本数据类型,所以 ...
- PhoenixFD插件流体模拟——UI布局【Simulation】详解
前言 之前使用RealFlow做流体模拟,但是总得和3ds导来导去,略显麻烦,特意学习PhoenixFD插件,直接在3ds中进行流体模拟.若读者有更好的流体模拟方法,欢迎在评论区交流. 原文地址:ht ...
- truecrype加密卷的使用
truecrype7.1 文件加密 隐藏加密 密钥加密码双重保护
- fortitoken
1.token状态为error,且不能分配给用户使用 解决: 关联有User的token状态是error的原因是:用户一直并未使用.
- 10.13 新版本go on~
上午1.5 终审 and 排期 合同管理那边又是切换选项时各种联动,我第一想法是 好麻烦,不想做这个...第二想法才是给我做吧 锻炼锻炼我 然后 分任务的时候 分给我了,,哈哈 开心 虽然我没想躲 但 ...
- 113. Path Sum II 输出每个具体路径
[抄题]: Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the gi ...
- 初始Spring mvc
转自:http://elf8848.iteye.com/blog/875830很棒的一篇博客,想了解SpringMvc的入门选手可以去看看. 一,核心类与接口: DispatcherServlet - ...
- 如何自行搭建一个威胁感知大脑 SIEM?| 硬创公开课
如何自行搭建一个威胁感知大脑 SIEM?| 硬创公开课 本文作者:谢幺 2017-03-10 10:09 专题:硬创公开课 导语:十年安全产品经验的百度安全专家兜哥,手把手教你用开源项目搭建SIEM安 ...