7天入门Python 6 — 输入输出、文件及OS

专栏自述:随着这几年机器学习火爆,楼主写了Java好多年,python其实也会写,但是缺乏系统性梳理,所以搞一个python栏目,系统性梳理的同时也把python的知识做一些梳理,欢迎查阅,欢迎一起学习python

传送门:

输出格式化

Python三种输出值的方式: 表达式语句和 print() 函数,第三种方式是使用文件对象的 write() 方法,标准输出文件可以用 sys.stdout 引用。

如果你希望输出的形式更加多样,可以使用 str.format() 函数来格式化输出值。

如果你希望将输出的值转成字符串,可以使用 repr() 或 str() 函数来实现。

  • str(): 函数返回一个用户易读的表达形式。
  • repr(): 产生一个解释器易读的表达形式,函数可以转义字符串中的特殊字符,并且参数可以是python的任何对象
  • rjust(): 可以将字符串靠右, 并在左边填充空格。
  • ljust(): 可以将字符串靠左, 并在左边填充空格。
  • center(): 可以将字符串居中, 并在两边填充空格。
  • zfill(): 在数字左边填充 0
  • str.format(): 将会被 format() 中的参数替换

实例:

import math

print("==========str、repr输出实例==========");
s = "Hello World"
s1 = "Hello World\n"
# str() 实例
print("str实例:" + str(s))
print("str特殊字符实例:" + str(s1)) #str函数对 \n 会进行换行

# repr() 实例
print("repr实例:" + repr(s))
print("repr特殊字符实例:" + repr(s1))   #repr函数可以转义字符串中的特殊字符

print("\n==========占位输出实例==========")
print("zfill实例:" + '12'.zfill(5))
print("ljust实例:" + '12'.ljust(5) + "#")
print("center实例:" + '12'.center(5) + "#")
print("rjust实例如下:")
for x in range(1, 5):
     print(repr(x).rjust(2), repr(x*x).rjust(3), end=' ')
     # 注意前一行 'end' 的使用
     print(repr(x*x*x).rjust(4))

print("\n==========str.format() 实例==========")
print('{}网址: "{}!"'.format('百度搜索', 'www.baidu.com'))
#括号中的数字用于指向传入对象在 format() 中的位置
print('{0} 和 {1}'.format('Google', 'Runoob'))
#括号中的关键字参数会指向使用该名字的参数的值
print('{name}网址: {site}'.format(name='百度搜索', site='www.baidu.com'))
#位置及关键字参数可以任意的结合
print('站点列表 {0}, {1}, 和 {other}。'.format('Google', 'Runoob', other='Taobao'))
#!a (使用 ascii()), !s (使用 str()) 和 !r (使用 repr()) 可以用于在格式化某个值之前对其进行转化
print('常量 PI 的值近似为: {!r}。'.format(math.pi))
#在 : 后传入一个整数, 可以保证该域至少有这么多的宽度
print('常量 PI 的值近似为 {0:.3f}。'.format(math.pi))
table = {'Google': 1, 'Runoob': 2, 'Taobao': 3}
for name, number in table.items():
    print('{0:10} ==> {1:10d} '.format(name, number))
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("\n==========% 实例==========")
print('常量 PI 的值近似为:%5.3f。' % math.pi)

输出结果:

==========str、repr输出实例==========
str实例:Hello World
str特殊字符实例:Hello World

repr实例:'Hello World'
repr特殊字符实例:'Hello World\n'

==========占位输出实例==========
zfill实例:00012
ljust实例:12   #
center实例:  12 #
rjust实例如下:
 1   1    1
 2   4    8
 3   9   27
 4  16   64

==========str.format() 实例==========
百度搜索网址: "www.baidu.com!"
Google 和 Runoob
百度搜索网址: www.baidu.com
站点列表 Google, Runoob, 和 Taobao。
常量 PI 的值近似为: 3.141592653589793。
常量 PI 的值近似为 3.142。
Google     ==>          1 
Runoob     ==>          2 
Taobao     ==>          3 
Runoob: 2; Google: 1; Taobao: 3
Runoob: 2; Google: 1; Taobao: 3

==========% 实例==========
常量 PI 的值近似为:3.142。

读取键盘输入

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

实例:

#!/usr/bin/python3

str = input("请输入:");
print ("你输入的内容是: ", str)

输入输出结果:

请输入:百度搜索
你输入的内容是:  百度搜索

文件操作

创建文件对象

语法:

open(filename, mode)       
# open() 将会返回一个 file 对象
# filename:包含了你要访问的文件名称的字符串值。
# mode:决定了打开文件的模式:只读,写入,追加等。

完整语法:

open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True)
# file: 必需,文件路径(相对或者绝对路径)。
# mode: 可选,文件打开模式,默认读
# buffering: 设置缓冲
# encoding: 一般使用utf8
# errors: 报错级别
# newline: 区分换行符
# closefd: 传入的file参数类型

模式汇总

模式描述
r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。
r+打开一个文件用于读写。文件指针将会放在文件的开头。
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
w打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
w+打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

实例:

#!/usr/bin/python3

# 打开一个文件
f = open("D:\\test.txt", "w")
f.write("来一个简单的文件测试\n")
# 关闭打开的文件
f.close()

结果:

文件对象方法

  • read():读取一定数目的数据, 然后作为字符串或字节对象返回

  • readline():读取单独的一行,换行符为 '\n'。f.readline() 如果返回一个空字符串, 说明已经已经读取到最后一行

  • readlines():返回该文件中包含的所有行

  • write():将 string 写入到文件中, 然后返回写入的字符数

  • tell():返回文件对象当前所处的位置, 它是从文件开头开始算起的字节数

  • seek():改变文件当前的位置, 使用 f.seek(offset, from_what) 函数;from_what 的值, 如果是 0 表示开头, 如果是 1 表示当前位置, 2 表示文件的结尾;offset 负数表示往前移动,正数表示往后移动

  • close():调用 f.close() 来关闭文件并释放系统的资源,如果尝试再调用该文件,则会抛出异常

实例:

#!/usr/bin/python3

# 打开一个文件
f = open("D:\\text.txt", "w+")
for i in range(1, 4):
    f.write("来一个简单的文件测试{}\n".format(i))


print("========= f.tell实例==========")
print("文件指针位置: {}".format(f.tell()))


print("\n========= f.read实例==========")
#重新调整到文件头
f.seek(0, 0)
print(f.read())

print("\n========= f.readlines 实例==========")
#重新调整到文件头
f.seek(0, 0)
lines = f.readlines()
print(lines)
for index, str in enumerate(lines):
    print("行数 {} 内容 {}".format(index, str), end='')

# 关闭打开的文件
f.close()

结果:

========= f.tell实例==========
文件指针位置: 69

========= f.read实例==========
来一个简单的文件测试1
来一个简单的文件测试2
来一个简单的文件测试3


========= f.readlines 实例==========
['来一个简单的文件测试1\n', '来一个简单的文件测试2\n', '来一个简单的文件测试3\n']
行数 0 内容 来一个简单的文件测试1
行数 1 内容 来一个简单的文件测试2
行数 2 内容 来一个简单的文件测试3

Process finished with exit code 0

OS 文件/目录方法

序号

方法描述
1

os.access(path, mode)     

检验权限模式
2os.chdir(path)改变当前工作目录
3os.chflags(path, flags)设置路径的标记为数字标记。
4os.chmod(path, mode)更改权限
5os.chown(path, uid, gid)更改文件所有者
6os.chroot(path)改变当前进程的根目录
7os.close(fd)关闭文件描述符 fd
8os.closerange(fd_low, fd_high)关闭所有文件描述符,从 fd_low (包含) 到 fd_high (不包含), 错误会忽略
9os.dup(fd)复制文件描述符 fd
10os.dup2(fd, fd2)将一个文件描述符 fd 复制到另一个 fd2
11os.fchdir(fd)通过文件描述符改变当前工作目录
12os.fchmod(fd, mode)改变一个文件的访问权限,该文件由参数fd指定,参数mode是Unix下的文件访问权限。
13os.fchown(fd, uid, gid)修改一个文件的所有权,这个函数修改一个文件的用户ID和用户组ID,该文件由文件描述符fd指定。
14os.fdatasync(fd)强制将文件写入磁盘,该文件由文件描述符fd指定,但是不强制更新文件的状态信息。
15os.fdopen(fd[, mode[, bufsize]])通过文件描述符 fd 创建一个文件对象,并返回这个文件对象
16os.fpathconf(fd, name)返回一个打开的文件的系统配置信息。name为检索的系统配置的值,它也许是一个定义系统值的字符串,这些名字在很多标准中指定(POSIX.1, Unix 95, Unix 98, 和其它)。
17os.fstat(fd)返回文件描述符fd的状态,像stat()。
18os.fstatvfs(fd)返回包含文件描述符fd的文件的文件系统的信息,Python 3.3 相等于 statvfs()。
19os.fsync(fd)强制将文件描述符为fd的文件写入硬盘。
20os.ftruncate(fd, length)裁剪文件描述符fd对应的文件, 所以它最大不能超过文件大小。
21os.getcwd()返回当前工作目录
22os.getcwdu()返回一个当前工作目录的Unicode对象
23os.isatty(fd)如果文件描述符fd是打开的,同时与tty(-like)设备相连,则返回true, 否则False。
24os.lchflags(path, flags)设置路径的标记为数字标记,类似 chflags(),但是没有软链接
25os.lchmod(path, mode)修改连接文件权限
26os.lchown(path, uid, gid)更改文件所有者,类似 chown,但是不追踪链接。
27os.link(src, dst)创建硬链接,名为参数 dst,指向参数 src
28os.listdir(path)返回path指定的文件夹包含的文件或文件夹的名字的列表。
29os.lseek(fd, pos, how)设置文件描述符 fd当前位置为pos, how方式修改: SEEK_SET 或者 0 设置从文件开始的计算的pos; SEEK_CUR或者 1 则从当前位置计算; os.SEEK_END或者2则从文件尾部开始. 在unix,Windows中有效
30os.lstat(path)像stat(),但是没有软链接
31os.major(device)从原始的设备号中提取设备major号码 (使用stat中的st_dev或者st_rdev field)。
32os.makedev(major, minor)以major和minor设备号组成一个原始设备号
33os.makedirs(path[, mode])递归文件夹创建函数。像mkdir(), 但创建的所有intermediate-level文件夹需要包含子文件夹。
34os.minor(device)从原始的设备号中提取设备minor号码 (使用stat中的st_dev或者st_rdev field )。
35os.mkdir(path[, mode])以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 0777 (八进制)。
36os.mkfifo(path[, mode])创建命名管道,mode 为数字,默认为 0666 (八进制)
37os.mknod(filename[, mode=0600, device])创建一个名为filename文件系统节点(文件,设备特别文件或者命名pipe)。
38os.open(file, flags[, mode])打开一个文件,并且设置需要的打开选项,mode参数是可选的
39os.openpty()打开一个新的伪终端对。返回 pty 和 tty的文件描述符。
40os.pathconf(path, name)返回相关文件的系统配置信息。
41os.pipe()创建一个管道. 返回一对文件描述符(r, w) 分别为读和写
42os.popen(command[, mode[, bufsize]])从一个 command 打开一个管道
43os.read(fd, n)从文件描述符 fd 中读取最多 n 个字节,返回包含读取字节的字符串,文件描述符 fd对应文件已达到结尾, 返回一个空字符串。
44os.readlink(path)返回软链接所指向的文件
45os.remove(path)删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory。
46os.removedirs(path)递归删除目录。
47os.rename(src, dst)重命名文件或目录,从 src 到 dst
48os.renames(old, new)递归地对目录进行更名,也可以对文件进行更名。
49os.rmdir(path)删除path指定的空目录,如果目录非空,则抛出一个OSError异常。
50os.stat(path)获取path指定的路径的信息,功能等同于C API中的stat()系统调用。
51os.stat_float_times([newvalue])决定stat_result是否以float对象显示时间戳
52os.statvfs(path)获取指定路径的文件系统统计信息
53os.symlink(src, dst)创建一个软链接
54os.tcgetpgrp(fd)返回与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组
55os.tcsetpgrp(fd, pg)设置与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组为pg。
56

os.tempnam([dir[, prefix]])

Python3 中已删除。返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除。
57

os.tmpfile()

Python3 中已删除。返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除。
58

os.tmpnam()

Python3 中已删除。为创建一个临时文件返回一个唯一的路径
59os.ttyname(fd)返回一个字符串,它表示与文件描述符fd 关联的终端设备。如果fd 没有与终端设备关联,则引发一个异常。
60os.unlink(path)删除文件路径
61os.utime(path, times)返回指定的path文件的访问和修改的时间。
62os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])输出在文件夹中的文件名通过在树中游走,向上或者向下。
63os.write(fd, str)写入字符串到文件描述符 fd中. 返回实际写入的字符串长度
64os.path 模块获取文件的属性信息。

pickle 模块

python的pickle模块实现了基本的数据序列和反序列化。通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储;通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。

# 将对象 obj 序列化到 file,采用 protocol,protocol可不传,默认0
pickle.dump(obj, file, [,protocol])
# 将file 内容反序列成对象
x = pickle.load(file)

写入:

#!/usr/bin/python3
import pickle

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

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

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

# protocol默认0,采用协议 0
pickle.dump(data1, output)

pickle.dump(data2, output, -1)

output.close()

读出:

#!/usr/bin/python3
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()

输出:

{'a': [1, 2.0, 3, (4+6j)], 'b': ('string', 'Unicode string'), 'c': None}
[1, 2, 3, <Recursion on list with id=2040109095880>]

下一篇:待完善

感兴趣的同学可以点关注哦,持续更新~

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值