本文基于pycharm编译器,也可以使用Anaconda 里的编译器,将讲解一些python的一些基础语法知识,是对上篇文章的补充.
文件是计算机中存储数据的一种方式,指计算机中用来存储数据、程序、图像、音频、视频等的一种信息存储单位。
文件可以包含多种格式的数据和不同类型的内容,如文本、图像、音频、视频等,其文件格式也是多种多样的,例如TXT、PDF、JPG、MP3、MP4等。
文件通常存储在计算机硬盘、U盘、移动硬盘等存储设备中,用户可以通过文件管理器或专业软件等方式进行管理和使用。
内存和硬盘都是计算机存储数据的设备。内存是临时存储设备,也被称为随机访问存储器(RAM),其作用是存储系统正在运行的程序和处理数据所需的临时数据。当程序被关闭或计算机被关闭时,内存中的数据就会被清除。硬盘是永久性存储设备,也被称为持久性存储器。它存储着计算机的操作系统、程序文件、文档、图片、音乐等文件,不会因为计算机关闭而丢失。内存和硬盘之间的关系是:计算机在运行程序时,会将程序及其需要处理的数据从硬盘中加载到内存中,然后在内存中进行处理和运行。当程序运行完毕后,计算机将数据再次写回硬盘,以便后续使用。因此,内存和硬盘在计算机运作过程中密不可分,两者的协调使用可以提高计算机的运行速度和效率。
数据都是保存在硬盘上的
一个机器上, 会存在很多文件,为了让这些文件更方面的被组织,往往会使用很多的"文件夹"(也叫做目录)来整理文件.
实际一个文件往往是放在一系列的目录结构之中的.
为了方便确定一个文件所在的位置 使用文件路径来进行描述
例如,QQ.exe这个文件,描述这个文件的位置,就可以使用路径"D:\QQ\Bin\QQ.exe"来表示.
D: 表示 盘符. 不区分大小写.
每一个\ 表示一级目录. 当前 QQ.exe 就是放在"D 盘下的QQ目录下的 Bin 目录中".
目录之间的分隔符,可以使用\ 也可以使用 /.一般在编写代码的时候使用 / 更方便.
上述以 盘符 开头的路径, 我们也称为 绝对路径.
除了绝对路径之外,还有一种常见的表示方式是 相对路径,相对路径需要先指定一个基准目录,然后以基准目录为参照点,间接的找到目标文件.
描述一个文件的位置, 使用 绝对路径 和 相对路径 都是可以的. 对于新手来说, 使用 绝对路径 更简单更好理解,也不容易出错.
要使用文件, 主要是通过文件来保存数据,并且在后续把保存的数据读取出来.
但是要想读写文件,需要先 “打开文件”,读写完毕之后还要 “关闭文件”.
在计算机,把远程操纵的“遥控器”称为句柄
使用内建函数 open 打开一个文件.
f = open('d:/test.txt', 'r')
第一个参数是一个字符串,表示要打开的文件路径
第二个参数是一个字符串,表示打开方式. 其中 r 表示按照读方式打开.w 表示按照写方式打开. a 表示追加写方式打开.
如果打开文件成功,返回一个文件对象. 后续的读写文件操作都是围绕这个文件对象展开.
如果打开文件失败(比如路径指定的文件不存在),就会抛出异常.
'r'
:只读模式,在该模式下打开的文件只能读取,不能修改和写入。'w'
:写入模式,在该模式下打开的文件可供写入,如果该文件已经存在,则会清空原有内容,如果不存在,则会创建新文件。'a'
:追加模式,在该模式下打开的文件可以在文件末尾进行写入。以下是打开文件并读取其内容的代码示例:
# 打开文件
file = open("example.txt", "r")
# 读取文件内容
content = file.read()
# 输出内容
print(content)
# 关闭文件
file.close()
在读取完文件后,一定要记得关闭文件,避免造成资源浪费和文件损坏。
f.close()
使用完毕的文件要记得及时关闭!
# 打开文件个数的上限
flist = []
count = Θ
while True:
f = open('d:/Python环境/test.txt', 'r')
flist.append(f)
count += 1
print(f'打开文件的个数: {count}')
在系统中可以通过设置,来改变打开文件的上限
例如,在打开一个名为"example.txt"的文件并读取文件中的内容后,需要关闭文件,可以使用以下代码:
file = open("example.txt", "r")
content = file.read()
print(content)
file.close() # 关闭文件
在关闭文件之前,建议始终使用file.closed
方法先检查文件是否已经关闭,以避免出现错误。
文件打开之后, 就可以写文件了.
写文件, 要使用写方式打开,open 第二个参数设为
f = open('d:/test.txt', 'w')
f.write('hello')
f.close()
用记事本打开文件, 即可看到文件修改后的内容.
f = open('d:/test.txt', 'r')
f.write('hello')
f.close()
使用’w’一旦打开文件成功,就会清空文件原有的数据.
f = open('d:/test.txt', 'w')
f.write('hello')
f.close()
f = open('d:/test.txt', 'a')
f.write('world')
f.close()
读文件内容需要使用 ‘r’ 的方式打开文件
f = open('d:/test.txt', 'r')
result = f.read(2)
print (result)
f.close()
如果文件是多行文本, 可以使用 for 循环一次读取一行.
# 更常见的需求,是按行来读取
#最简单的办法,直接 for 循环.
f = open('d:/Python环境/test.txt', 'r', encoding='utf8')
for line in f:
print(f'line = {line}', end='')#末尾为空
f.close()
先构造一个多行文件.
f = open('d:/test.txt', 'r')
for line in f:
print(f'line = {line}')
f.close()
Python读取文件的方法:
# 使用 readlines 方法直接把整个文件所有内容都读出来,按照行组织到一个列表里.
f = open('d:/Python环境/test.txt', 'r', encoding='utf8')
print(lines)
lines = f.readlines()
f.close()
代码示例:
# 打开文件
f = open('example.txt', 'r')
# 读取文件内容
content = f.read()
# 输出文件内容
print(content)
# 关闭文件
f.close()
注意:
在Python中读取文件时,可以使用open函数打开文件并指定文件的编码方式。例如:
with open('filename.txt', 'r', encoding='utf-8') as f:
content = f.read()
其中,'utf-8’代表文件的编码方式。如果不指定编码方式,则默认使用系统默认编码方式进行读取。如果文件的编码方式与指定的不一致,则可能会导致乱码或错误的解析。
Python的上下文管理器是一种用于管理资源的特殊对象,它支持用"with"语句来简化资源管理的代码。上下文管理器可以确保资源(例如文件或网络连接等)在使用之后正确地释放。
在Python中,上下文管理器通过实现 “enter” 和 “exit” 这两个特殊方法来实现。当使用 “with” 语句打开一个上下文管理器时,会先调用 “enter” 方法,接着执行语句块,最后调用 “exit” 方法释放资源。
例如,以下是一个用于打开文件的上下文管理器的示例:
class MyFile:
def __init__(self, filename):
self.filename = filename
def __enter__(self):
self.file = open(self.filename, 'r')
return self.file
def __exit__(self, exc_type, exc_value, traceback):
self.file.close()
with MyFile('example.txt') as file:
for line in file:
print(line)
with MyFile('example.txt') as file
的意思是,给file赋值为MyFile('example.txt')
在上述示例中,类MyFile实现了 enter 和 exit 方法,这使得该类的实例可以作为上下文管理器使用。在使用 “with” 语句时,将会调用 enter 方法来打开文件,并返回文件对象,接着就可以在语句块中使用该文件对象。在语句块执行完毕后,将会调用 exit 方法来关闭文件。
这个可以和c++的智能指针关联
库 就是是别人已经写好了的代码, 可以让我们直接拿来用.
一个编程语言能不能流行起来,一方面取决于语法是否简单方便容易学习, 一方面取决于生态是否完备.
所谓的"生态"指的就是语言是否有足够丰富的库,来应对各种各样的场景.
实际开发中,也并非所有的代码都自己手写,而是要充分利用现成的库, 简化开发过程.
按照库的来源,可以大致分成两大类
咱们自己也可以实现 “第三方库” 发布出去, 交给别人来使用.
认识标准库
Python 自身内置了非常丰富的库.
在 Python 官方文档上可以看到这些库的内容.
Python标准库是Python内置的一组模块,包含了大量的常用函数和工具,如文件I/O、网络通信、字符串操作、数据结构、日期和时间处理、正则表达式、多线程等。Python标准库是Python开发者非常常用的一组工具,使用Python标准库可以大大提高开发效率。
Python标准库包含以下模块:
除了标准库,Python还有大量的第三方库和框架,如NumPy、Pandas、Matplotlib、Django等,这些库和框架大大扩展了Python的功能和应用领域。
Python第三方库是指由Python社区中的开发者所开发的,可供其他Python程序员使用的外部库,可以提供各种功能,如图形界面、数据分析、网络编程、爬虫、机器学习等等。
以下是一些常见的Python第三方库:
NumPy:用于处理科学计算、数学计算和数值分析的库。
Pandas:用于数据处理和数据分析的库,可以用来读写各种格式的数据文件。
Matplotlib:用于绘制二维图表和三维图表的库,可生成多种类型的图形。
Scikit-learn:用于机器学习和数据挖掘的库,包括常用的机器学习算法。
Requests:用于发送HTTP请求和处理HTTP响应的库,可以用于爬虫和网页自动化测试等等。
Django:用于Web应用程序开发的框架,提供了完整的MVC架构、自带ORM、模版引擎、路由分发和中间件等功能。
Flask:轻量级的Web应用程序框架,提供了路由分发、模版引擎、中间件等功能,适合用于小型Web应用程序的开发。
Pygame:用于开发游戏的库,提供了图形界面和音频播放等功能。
TensorFlow:用于机器学习和深度学习的库,支持GPU加速和分布式计算,可用于实现各种机器学习和深度学习模型。
例如,举一个时间序列的例子
#import datetime
#from datetime import datetime
import datetime as dt
# 先构造 datetime 变量
date1 = dt.datetime(year=2012, month=2, day=14)
date2 = dt.datetime(year=2016, month=2, day=3)
print(date2 - date1)