python 文件输入输出

一、输入输出

1. 输出格式美化

Python两种输出值的方式: 表达式语句和 print() 函数。
第三种方式是使用文件对象的 write() 方法,标准输出文件可以用 sys.stdout 引用。
如果你希望输出的形式更加多样,可以使用 str.format() 函数来格式化输出值。
如果你希望将输出的值转成字符串,可以使用 repr() 或 str() 函数来实现。
    str(): 函数返回一个用户易读的表达形式。
    repr(): 产生一个解释器易读的表达形式。

2. 旧式字符串格式化

% 操作符也可以实现字符串格式化。 它将左边的参数作为类似 sprintf() 式的格式化字符串, 而将右边的代入, 然后返回格式化后的字符串.
注意:因为 str.format() 是比较新的函数, 大多数的 Python 代码仍然使用 % 操作符。但是因为这种旧式的格式化最终会从该语言中移除, 应该更多的使用 str.format().

3. 读取键盘输入

Python 提供了 input() 内置函数从标准输入读入一行文本,默认的标准输入是键盘。

4. 读和写文件

open() 将会返回一个 file 对象,基本语法格式如下:
    open(filename, mode)
    filename:包含了你要访问的文件名称的字符串值。
    mode:决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
不同模式打开文件的完全列表:
    模式	描述
    r	以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
    rb	以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。
    r+	打开一个文件用于读写。文件指针将会放在文件的开头。
    rb+	以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
    w	打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
    wb	以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
    w+	打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
    wb+	以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
    a	打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
    ab	以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
    a+	打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
    ab+	以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

5. 文件对象的方法

本节中剩下的例子假设已经创建了一个称为 f 的文件对象。
     f.read()
为了读取一个文件的内容,调用 f.read(size), 这将读取一定数目的数据, 然后作为字符串或字节对象返回。
size 是一个可选的数字类型的参数。 当 size 被忽略了或者为负, 那么该文件的所有内容都将被读取并且返回。
f.readline()
    f.readline() 会从文件中读取单独的一行。换行符为 '\n'。f.readline() 如果返回一个空字符串, 说明已经已经读取到最后一行。
f.readlines()
    f.readlines() 将返回该文件中包含的所有行。
    如果设置可选参数 sizehint, 则读取指定长度的字节, 并且将这些字节按行分割。
另一种方式是迭代一个文件对象然后读取每行:
f.write()
    f.write(string) 将 string 写入到文件中, 然后返回写入的字符数。
f.tell()
    f.tell() 用于返回文件当前的读/写位置(即文件指针的位置)。文件指针表示从文件开头开始的字节数偏移量。f.tell() 返回一个整数,表示文件指针的当前位置。
f.seek()
    如果要改变文件指针当前的位置, 可以使用 f.seek(offset, from_what) 函数。
    f.seek(offset, whence) 用于移动文件指针到指定位置。
    offset 表示相对于 whence 参数的偏移量,from_what 的值, 如果是 0 表示开头, 如果是 1 表示当前位置, 2 表示文件的结尾,例如:
        seek(x,0) : 从起始位置即文件首行首字符开始移动 x 个字符
        seek(x,1) : 表示从当前位置往后移动x个字符
        seek(-x,2):表示从文件的结尾往前移动x个字符
    f.close()
        在文本文件中 (那些打开文件的模式下没有 b 的), 只会相对于文件起始位置进行定位。
        当你处理完一个文件后, 调用 f.close() 来关闭文件并释放系统的资源,如果尝试再调用该文件,则会抛出异常。
with:
    当处理一个文件对象时, 使用 with 关键字是非常好的方式。在结束后, 它会帮你正确的关闭文件。 而且写起来也比 try - finally 语句块要简短:
        with open('/tmp/foo.txt', 'r') as f:
             read_data = f.read()
        f.closed
    True
        文件对象还有其他方法, 如 isatty() 和 trucate(), 但这些通常比较少用。

6. pickle 模块

python的pickle模块实现了基本的数据序列和反序列化。
通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储。
通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。
基本接口:
    pickle.dump(obj, file, [,protocol])
有了 pickle 这个对象, 就能对 file 以读取的形式打开:
    x = pickle.load(file)
注解:从 file 中读取一个字符串,并将它重构为原来的python对象。
file: 类文件对象,有read()和readline()接口。

二、文件操作

1. File(文件) 方法

open() 方法
Python open() 方法用于打开一个文件,并返回文件对象。
在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 OSError。
注意:使用 open() 方法一定要保证关闭文件对象,即调用 close() 方法。
open() 函数常用形式是接收两个参数:文件名(file)和模式(mode)。
    open(file, mode='r')
完整的语法格式为:
     open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
参数说明:
    file: 必需,文件路径(相对或者绝对路径)。
    mode: 可选,文件打开模式
    buffering: 设置缓冲
    encoding: 一般使用utf8
    errors: 报错级别
    newline: 区分换行符
    closefd: 传入的file参数类型
    opener: 设置自定义开启器,开启器的返回值必须是一个打开的文件描述符。

2. mode 参数有:

模式	描述
t	文本模式 (默认)。
x	写模式,新建一个文件,如果该文件已存在则会报错。
b	二进制模式。
+	打开一个文件进行更新(可读可写)。
U	通用换行模式(Python 3 不支持)。
r	以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb	以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。
r+	打开一个文件用于读写。文件指针将会放在文件的开头。
rb+	以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。
w	打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb	以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
w+	打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb+	以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
a	打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab	以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+	打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+	以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
默认为文本模式,如果要以二进制模式打开,加上 b 。

3. file 对象

file 对象使用 open 函数来创建,下表列出了 file 对象常用的函数:
序号	方法及描述
file.close()    关闭文件。关闭后文件不能再进行读写操作。
file.flush()    刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。
file.fileno()   返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。
file.isatty()   如果文件连接到一个终端设备返回 True,否则返回 False。
file.next() Python 3 中的 File 对象不支持 next() 方法。返回文件下一行。
file.read([size])   从文件读取指定的字节数,如果未给定或为负则读取所有。
file.readline([size])   读取整行,包括 "\n" 字符。
file.readlines([sizeint])   读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。
file.seek(offset[, whence]) 移动文件读取指针到指定位置
file.tell() 返回文件当前位置。
file.truncate([size])   从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后后面的所有字符被删除,其中 windows 系统下的换行代表2个字符大小。
file.write(str) 将字符串写入文件,返回的是写入的字符长度。
file.writelines(sequence)   向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。

三、 OS 文件操作

1. OS 文件/目录方法

os 模块提供了非常丰富的方法用来处理文件和目录

序号	方法及描述

os.access(path, mode)检验权限模式
os.chdir(path)  改变当前工作目录
os.chflags(path, flags) 设置路径的标记为数字标记。
os.chmod(path, mode)    更改权限
os.chown(path, uid, gid)    更改文件所有者
os.chroot(path) 改变当前进程的根目录
os.close(fd)    关闭文件描述符 fd
os.closerange(fd_low, fd_high)  关闭所有文件描述符,从 fd_low (包含) 到 fd_high (不包含), 错误会忽略
os.dup(fd)  复制文件描述符 fd
os.dup2(fd, fd2)    将一个文件描述符 fd 复制到另一个 fd2
os.fchdir(fd)   通过文件描述符改变当前工作目录
os.fchmod(fd, mode) 改变一个文件的访问权限,该文件由参数fd指定,参数mode是Unix下的文件访问权限。
os.fchown(fd, uid, gid) 修改一个文件的所有权,这个函数修改一个文件的用户ID和用户组ID,该文件由文件描述符fd指定。
os.fdatasync(fd)   强制将文件写入磁盘,该文件由文件描述符fd指定,但是不强制更新文件的状态信息。
os.fdopen(fd[, mode[, bufsize]])    通过文件描述符 fd 创建一个文件对象,并返回这个文件对象
os.fpathconf(fd, name)  返回一个打开的文件的系统配置信息。name为检索的系统配置的值,它也许是一个定义系统值的字符串,这些名字在很多标准中指定(POSIX.1, Unix 95, Unix 98, 和其它)。
os.fstat(fd)    返回文件描述符fd的状态,像stat()。
os.fstatvfs(fd) 返回包含文件描述符fd的文件的文件系统的信息,Python 3.3 相等于 statvfs()。
os.fsync(fd)    强制将文件描述符为fd的文件写入硬盘。
os.ftruncate(fd, length)    裁剪文件描述符fd对应的文件, 所以它最大不能超过文件大小。
os.getcwd() 返回当前工作目录
os.getcwdb()    返回一个当前工作目录的Unicode对象
os.isatty(fd)   如果文件描述符fd是打开的,同时与tty(-like)设备相连,则返回true, 否则False。
os.lchflags(path, flags)    设置路径的标记为数字标记,类似 chflags(),但是没有软链接
os.lchmod(path, mode)   修改连接文件权限
os.lchown(path, uid, gid)   更改文件所有者,类似 chown,但是不追踪链接。
os.link(src, dst)   创建硬链接,名为参数 dst,指向参数 src
os.listdir(path)    返回path指定的文件夹包含的文件或文件夹的名字的列表。
os.lseek(fd, pos, how)  设置文件描述符 fd当前位置为pos, how方式修改: SEEK_SET 或者 0 设置从文件开始的计算的pos; SEEK_CUR或者 1 则从当前位置计算; os.SEEK_END或者2则从文件尾部开始. 在unix,Windows中有效
os.lstat(path)  像stat(),但是没有软链接
os.major(device)    从原始的设备号中提取设备major号码 (使用stat中的st_dev或者st_rdev field)。
os.makedev(major, minor)    以major和minor设备号组成一个原始设备号
os.makedirs(path[, mode])   递归文件夹创建函数。像mkdir(), 但创建的所有intermediate-level文件夹需要包含子文件夹。
os.minor(device)    从原始的设备号中提取设备minor号码 (使用stat中的st_dev或者st_rdev field )。
os.mkdir(path[, mode])  以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 0777 (八进制)。
os.mkfifo(path[, mode]) 创建命名管道,mode 为数字,默认为 0666 (八进制)
os.mknod(filename[, mode=0600, device]) 创建一个名为filename文件系统节点(文件,设备特别文件或者命名pipe)。
os.open(file, flags[, mode])    打开一个文件,并且设置需要的打开选项,mode参数是可选的
os.openpty()    打开一个新的伪终端对。返回 pty 和 tty的文件描述符。
os.pathconf(path, name) 返回相关文件的系统配置信息。
os.pipe()   创建一个管道. 返回一对文件描述符(r, w) 分别为读和写
os.popen(command[, mode[, bufsize]])    从一个 command 打开一个管道
os.read(fd, n)  从文件描述符 fd 中读取最多 n 个字节,返回包含读取字节的字符串,文件描述符 fd对应文件已达到结尾, 返回一个空字符串。
os.readlink(path)   返回软链接所指向的文件
os.remove(path) 删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory。
os.removedirs(path) 递归删除目录。
os.rename(src, dst) 重命名文件或目录,从 src 到 dst
os.renames(old, new)    递归地对目录进行更名,也可以对文件进行更名。
os.rmdir(path)  删除path指定的空目录,如果目录非空,则抛出一个OSError异常。
os.stat(path)   获取path指定的路径的信息,功能等同于C API中的stat()系统调用。
os.stat_float_times([newvalue]) 决定stat_result是否以float对象显示时间戳
os.statvfs(path)    获取指定路径的文件系统统计信息
os.symlink(src, dst)    创建一个软链接
os.tcgetpgrp(fd)    返回与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组
os.tcsetpgrp(fd, pg)    设置与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组为pg。
os.tempnam([dir[, prefix]]) Python3 中已删除。返回唯一的路径名用于创建临时文件。
os.tmpfile()    Python3 中已删除。返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除。
os.tmpnam() Python3 中已删除。为创建一个临时文件返回一个唯一的路径
os.ttyname(fd)  返回一个字符串,它表示与文件描述符fd 关联的终端设备。如果fd 没有与终端设备关联,则引发一个异常。
os.unlink(path) 删除文件路径
os.utime(path, times)   返回指定的path文件的访问和修改的时间。
os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])   输出在文件夹中的文件名通过在树中游走,向上或者向下。
os.write(fd, str)   写入字符串到文件描述符 fd中. 返回实际写入的字符串长度
os.path 模块  获取文件的属性信息。
os.pardir() 获取当前目录的父目录,以字符串形式显示目录名。
os.replace()    重命名文件或目录。

四、代码概览(输出输出)

#!/usr/bin/env python3
# -*- coding: UTF-8 -*-
# @Date : 2024/4/16 10:30
# @Author : water
# @Description : 输入输出


"""
输出格式美化
    Python两种输出值的方式: 表达式语句和 print() 函数。
    第三种方式是使用文件对象的 write() 方法,标准输出文件可以用 sys.stdout 引用。
    如果你希望输出的形式更加多样,可以使用 str.format() 函数来格式化输出值。
    如果你希望将输出的值转成字符串,可以使用 repr() 或 str() 函数来实现。
        str(): 函数返回一个用户易读的表达形式。
        repr(): 产生一个解释器易读的表达形式。
旧式字符串格式化
    % 操作符也可以实现字符串格式化。 它将左边的参数作为类似 sprintf() 式的格式化字符串, 而将右边的代入, 然后返回格式化后的字符串.
    注意:因为 str.format() 是比较新的函数, 大多数的 Python 代码仍然使用 % 操作符。但是因为这种旧式的格式化最终会从该语言中移除, 应该更多的使用 str.format().
读取键盘输入
    Python 提供了 input() 内置函数从标准输入读入一行文本,默认的标准输入是键盘。
读和写文件
    open() 将会返回一个 file 对象,基本语法格式如下:
        open(filename, mode)
        filename:包含了你要访问的文件名称的字符串值。
        mode:决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
    不同模式打开文件的完全列表:
        模式	描述
        r	以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
        rb	以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。
        r+	打开一个文件用于读写。文件指针将会放在文件的开头。
        rb+	以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
        w	打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
        wb	以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
        w+	打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
        wb+	以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
        a	打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
        ab	以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
        a+	打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
        ab+	以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
文件对象的方法
    本节中剩下的例子假设已经创建了一个称为 f 的文件对象。
         f.read()
    为了读取一个文件的内容,调用 f.read(size), 这将读取一定数目的数据, 然后作为字符串或字节对象返回。
    size 是一个可选的数字类型的参数。 当 size 被忽略了或者为负, 那么该文件的所有内容都将被读取并且返回。
    f.readline()
        f.readline() 会从文件中读取单独的一行。换行符为 '\n'。f.readline() 如果返回一个空字符串, 说明已经已经读取到最后一行。
    f.readlines()
        f.readlines() 将返回该文件中包含的所有行。
        如果设置可选参数 sizehint, 则读取指定长度的字节, 并且将这些字节按行分割。
    另一种方式是迭代一个文件对象然后读取每行:
    f.write()
        f.write(string) 将 string 写入到文件中, 然后返回写入的字符数。
    f.tell()
        f.tell() 用于返回文件当前的读/写位置(即文件指针的位置)。文件指针表示从文件开头开始的字节数偏移量。f.tell() 返回一个整数,表示文件指针的当前位置。
    f.seek()
        如果要改变文件指针当前的位置, 可以使用 f.seek(offset, from_what) 函数。
        f.seek(offset, whence) 用于移动文件指针到指定位置。
        offset 表示相对于 whence 参数的偏移量,from_what 的值, 如果是 0 表示开头, 如果是 1 表示当前位置, 2 表示文件的结尾,例如:
            seek(x,0) : 从起始位置即文件首行首字符开始移动 x 个字符
            seek(x,1) : 表示从当前位置往后移动x个字符
            seek(-x,2):表示从文件的结尾往前移动x个字符
        f.close()
            在文本文件中 (那些打开文件的模式下没有 b 的), 只会相对于文件起始位置进行定位。
            当你处理完一个文件后, 调用 f.close() 来关闭文件并释放系统的资源,如果尝试再调用该文件,则会抛出异常。
    with:
        当处理一个文件对象时, 使用 with 关键字是非常好的方式。在结束后, 它会帮你正确的关闭文件。 而且写起来也比 try - finally 语句块要简短:
            with open('/tmp/foo.txt', 'r') as f:
                 read_data = f.read()
            f.closed
        True
            文件对象还有其他方法, 如 isatty() 和 trucate(), 但这些通常比较少用。
pickle 模块
    python的pickle模块实现了基本的数据序列和反序列化。
    通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储。
    通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。
    基本接口:
        pickle.dump(obj, file, [,protocol])
    有了 pickle 这个对象, 就能对 file 以读取的形式打开:
        x = pickle.load(file)
    注解:从 file 中读取一个字符串,并将它重构为原来的python对象。
    file: 类文件对象,有read()和readline()接口。
"""

# str()、repr() 函数

s = "hello world!"

print(repr(s))
print(str(1 / 7))

x = 10 * 3.25
y = 100 * 200
s = 'x 的值为: ' + repr(x) + ',  y 的值为:' + repr(y) + '...'
print(s)

#  repr() 函数可以转义字符串中的特殊字符
print(repr("\\\t\n"))

# repr() 的参数可以是 Python 的任何对象
print(repr((x, y, ('spam', 'eggs'))))

# 两种方式输出一个平方与立方的表:
for x in range(1, 11):
    print(repr(x).rjust(2), repr(x ** 2).rjust(3), end=' ')
    # Note use of 'end' on previous line
    print(repr(x ** 3).rjust(4))
print("------------------------------------------------------------------------")
for x in range(1, 11):
    print('{0:2d} {1:3d} {2:5d}'.format(x, x ** 2, x ** 3))

"""
注意:
    在第一个例子中, 每列间的空格由 print() 添加。
    这个例子展示了字符串对象的 rjust() 方法, 它可以将字符串靠右, 并在左边填充空格。
    还有类似的方法, 如 ljust() 和 center()。 这些方法并不会写任何东西, 它们仅仅返回新的字符串。
"""

# 另一个方法 zfill(), 它会在数字的左边填充 0,

print('12'.zfill(5))
print('-3.14'.zfill(7))
print('3.14159265359'.zfill(5))

# str.format() 的基本使用如下:
print('We are the {} who say "{}!"'.format('knights', 'Ni'))
# 在括号中的数字用于指向传入对象在 format() 中的位置,如下所示:
print('{0} and {1}'.format('spam', 'eggs'))
print('{1} and {0}'.format('spam', 'eggs'))
# 如果在 format() 中使用了关键字参数, 那么它们的值会指向使用该名字的参数。
print('This {food} is {adjective}.'.format(
    food='spam', adjective='absolutely horrible'))

# !a (使用 ascii()), !s (使用 str()) 和 !r (使用 repr()) 可以用于在格式化某个值之前对其进行转化:
print('The value of pi is approximately {0:.3f}.'.format(3.14159265))
import math

# 可选项 : 和格式标识符可以跟着字段名。 这就允许对值进行更好的格式化。 下面的例子将 Pi 保留到小数点后三位:
print('The value of pi is approximately {0:.3f}.'.format(math.pi))
print('The value of pi is approximately {0:.3g}.'.format(math.pi))
print('The value of pi is approximately {0:f}.'.format(math.pi))
print('The value of pi is approximately {!r}.'.format(math.pi))

# 在 : 后传入一个整数, 可以保证该域至少有这么多的宽度。 用于美化表格时很有用。
print('{0:10} {1:10}'.format('Fruit', 'Quantity'))

# 如果你有一个很长的格式化字符串, 而你不想将它们分开, 那么在格式化时通过变量名而非位置会是很好的事情。最简单的就是传入一个字典, 然后使用方括号 [] 来访问键值 :

table = {'Google': 1, 'Runoob': 2, 'Taobao': 3}
print('Runoob: {0[Runoob]:d}; Google: {0[Google]:d}; Taobao: {0[Taobao]:d}'.format(table))

# 也可以通过在 table 变量前使用 ** 来实现相同的功能:
print('Runoob: {Runoob:d}; Google: {Google:d}; Taobao: {Taobao:d}'.format(**table))

# 旧式字符串格式化
print('Value of pi is around %.3f.' % math.pi)

# 读取键盘输入
print(input('Enter something --> '))

# 将字符串写入到文件 foo.txt 中:
with open('foo.txt', 'w') as f:
    f.write('Hello World!')
f.close()


# 假定文件 foo.txt 已存在(上面实例中已创建)
with open('foo.txt') as f:
    for line in f:
        print(line, end='')

# f.write()
with open('foo.txt', 'a+') as f:
    f.write('SANDUO Hello World!')

# f.tell()
with open('foo.txt') as f:
    print(f.tell())

# pickle 使用
import pickle

# 使用pickle模块将数据对象保存到文件
data1 = {'a': [1, 2.0, 3, 4+6j],
         'b': ('string', u'Unicode string'),
         'c': None}

selfref_list = [1, 2, 3]
selfref_list.append(selfref_list)

output = open('data.pkl', 'wb')

# Pickle dictionary using protocol 0.
pickle.dump(data1, output)

# Pickle the list using the highest protocol available.
pickle.dump(selfref_list, output, -1)

output.close()


import pprint, pickle

# 使用pickle模块从文件中重构python对象
pkl_file = open('data.pkl', 'rb')

data1 = pickle.load(pkl_file)
pprint.pprint(data1)

data2 = pickle.load(pkl_file)
pprint.pprint(data2)

pkl_file.close()

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值