2021年8月15日(print的细节)

在使用print()函数输出数据时,想要改变默认的分割符或者行尾符。
可以使用sep和end关键字参数。

# seq指定输出时的分割符号,end指定结尾符号
print('A', 1, 2, sep=',', end='!!')

读取字节数据

如果想从二进制模式的文件中读取或写入文本数据,必须确保要进行解码和编码操作。

with open('somefile.bin', 'rb') as f:
    data = f.read(16)
    text = data.decode('utf-8')

with open('somefile.bin', 'wb') as f:
    text = 'Hello World'
    f.write(text.encode('utf-8'))

2021年8月15日(文件路径)

import os
path = '/Users/beazley/Data/data.csv'
os.path.basename(path) # 'data.csv'

os.path.dirname(path) # 'Users/beazley/Data'

os.path.join('tmp', 'data', os.path.basename(path)) # 'tmp/data/data.csv'

path = '~/Data/data.csv'
os.path.splitext(path) ('~/Data/data', '.csv')

判断文件或目录是否存在

os.path.exists('/etc/passwd')

获取文件夹中的文件列表,如果我们想过滤某些文件,可以结合os.path库中的一些函数来使用列表推导

import os

# 获得文件夹中的所有文件
names = [name for name in os.listdir('somedir') if os.path.isfile(os.path.join('somedir', name))]
# 获得所有的文件
dirnames = [name for name in os.listdir('somedir') if os.path.isdir(os.path.join('somedir', name))]

# 获得所有python文件
pyfiles = [name for name in os.listdir('somedir') if name.endswith('.py')]

# 对于文件名的匹配,使用glob
import glob
pyfiles = glob.glob('somedir/*.py')

二级目录

三级目录