python基础语法——文件与库

本文涉及的产品
应用实时监控服务-用户体验监控,每月100OCU免费额度
性能测试 PTS,5000VUM额度
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 本文基于pycharm编译器,也可以使用Anaconda 里的编译器,将讲解一些python的一些基础语法知识,是对上篇文章的补充.

基础语法


前言

本文基于pycharm编译器,也可以使用Anaconda 里的编译器,将讲解一些python的一些基础语法知识,是对上篇文章的补充.


文件

文件是什么

文件是计算机中存储数据的一种方式,指计算机中用来存储数据、程序、图像、音频、视频等的一种信息存储单位。

文件可以包含多种格式的数据和不同类型的内容,如文本、图像、音频、视频等,其文件格式也是多种多样的,例如TXT、PDF、JPG、MP3、MP4等。

文件通常存储在计算机硬盘、U盘、移动硬盘等存储设备中,用户可以通过文件管理器或专业软件等方式进行管理和使用。

内存和硬盘都是计算机存储数据的设备。内存是临时存储设备,也被称为随机访问存储器(RAM),其作用是存储系统正在运行的程序和处理数据所需的临时数据。当程序被关闭或计算机被关闭时,内存中的数据就会被清除。硬盘是永久性存储设备,也被称为持久性存储器。它存储着计算机的操作系统、程序文件、文档、图片、音乐等文件,不会因为计算机关闭而丢失。内存和硬盘之间的关系是:计算机在运行程序时,会将程序及其需要处理的数据从硬盘中加载到内存中,然后在内存中进行处理和运行。当程序运行完毕后,计算机将数据再次写回硬盘,以便后续使用。因此,内存和硬盘在计算机运作过程中密不可分,两者的协调使用可以提高计算机的运行速度和效率。

  1. 内存的空间更小,硬盘空间更大
  2. 内存访问更快,硬盘访问更慢
  3. 内存成本更贵,硬盘成本更便宜
  4. 内存的数据易失,硬盘的数据持久化存储.

数据都是保存在硬盘上的

文件路径

一个机器上, 会存在很多文件,为了让这些文件更方面的被组织,往往会使用很多的"文件夹"(也叫做目录)来整理文件.

实际一个文件往往是放在一系列的目录结构之中的.

为了方便确定一个文件所在的位置使用文件路径来进行描述

例如,QQ.exe这个文件,描述这个文件的位置,就可以使用路径"D:\QQ\Bin\QQ.exe"来表示.

D: 表示 盘符. 不区分大小写.

每一个\ 表示一级目录. 当前 QQ.exe 就是放在"D 盘下的QQ目录下的 Bin 目录中".

目录之间的分隔符,可以使用\ 也可以使用 /.一般在编写代码的时候使用 / 更方便.

上述以 盘符 开头的路径, 我们也称为 绝对路径.除了绝对路径之外,还有一种常见的表示方式是 相对路径,相对路径需要先指定一个基准目录,然后以基准目录为参照点,间接的找到目标文件.

描述一个文件的位置, 使用 绝对路径 和 相对路径 都是可以的. 对于新手来说,使用 绝对路径更简单更好理解,也不容易出错.

文件操作

要使用文件, 主要是通过文件来保存数据,并且在后续把保存的数据读取出来.

但是要想读写文件,需要先 “打开文件”,读写完毕之后还要 “关闭文件”.

在计算机,把远程操纵的“遥控器”称为句柄

1.打开文件

使用内建函数 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()

在读取完文件后,一定要记得关闭文件,避免造成资源浪费和文件损坏。

2. 关闭文件

  • 使用 close 方法关闭已经打开的文件.
f.close()

使用完毕的文件要记得及时关闭!

  • 一个程序能同时打开的文件个数, 是存在上限的.
# 打开文件个数的上限
flist = []
count = Θ
while True:
  f = open('d:/Python环境/test.txt', 'r')
  flist.append(f)
  count += 1
print(f'打开文件的个数: {count}')

在系统中可以通过设置,来改变打开文件的上限

  • 在Python中关闭文件的语法是:file_object.close()。

例如,在打开一个名为"example.txt"的文件并读取文件中的内容后,需要关闭文件,可以使用以下代码:

file = open("example.txt", "r")
content = file.read()
print(content)
file.close()   # 关闭文件

在关闭文件之前,建议始终使用file.closed方法先检查文件是否已经关闭,以避免出现错误。

3.写文件

文件打开之后, 就可以写文件了.

写文件, 要使用写方式打开,open 第二个参数设为

  • 使用 write 方法写入文件.
f = open('d:/test.txt', 'w')
f.write('hello')
f.close()

用记事本打开文件, 即可看到文件修改后的内容.

  • 如果是使用 ‘r’ 方式打开文件,则写入时会抛出异常.
f = open('d:/test.txt', 'r')
f.write('hello')
f.close()

使用’w’一旦打开文件成功,就会清空文件原有的数据.

  • 使用 ‘a’ 实现"追加写",此时原有内容不变,写入的内容会存在于之前文件内容的末尾.
f = open('d:/test.txt', 'w')
f.write('hello')
f.close()
f = open('d:/test.txt', 'a')
f.write('world')
f.close()

4. 读文件

读文件内容需要使用 ‘r’ 的方式打开文件

  • 使用 read 方法完成读操作. 参数表示"读取几个字符"
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读取文件的方法:

  1. 使用open函数打开文件,指定文件名和读取模式(‘r’)。
  2. 使用read方法读取整个文件内容,或者使用readline方法读取一行内容,或者使用readlines方法读取所有行并返回一个列表。
  3. 关闭文件,使用close方法进行关闭,释放文件资源。
# 使用 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()

注意:

  • 在使用open函数打开文件后,如果不进行关闭,会占用系统资源,因此必须使用close方法进行关闭。
  • 在程序结束时,Python会自动关闭所有未关闭的文件,但最好习惯性地使用close方法手动关闭文件。

在Python中读取文件时,可以使用open函数打开文件并指定文件的编码方式。例如:

with open('filename.txt', 'r', encoding='utf-8') as f:
    content = f.read()

其中,'utf-8’代表文件的编码方式。如果不指定编码方式,则默认使用系统默认编码方式进行读取。如果文件的编码方式与指定的不一致,则可能会导致乱码或错误的解析。

5.上下文管理器

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实现了 enterexit 方法,这使得该类的实例可以作为上下文管理器使用。在使用 “with” 语句时,将会调用 enter 方法来打开文件,并返回文件对象,接着就可以在语句块中使用该文件对象。在语句块执行完毕后,将会调用 exit 方法来关闭文件。

这个可以和c++的智能指针关联

使用库

库 就是是别人已经写好了的代码, 可以让我们直接拿来用.

一个编程语言能不能流行起来,一方面取决于语法是否简单方便容易学习, 一方面取决于生态是否完备.

所谓的"生态"指的就是语言是否有足够丰富的库,来应对各种各样的场景.

实际开发中,也并非所有的代码都自己手写,而是要充分利用现成的库, 简化开发过程.

按照库的来源,可以大致分成两大类

  • 标准库: Python 自带的库. 只要安装了 Python 就可以直接使用.
  • 第三方库: 其他人实现的库. 要想使用, 需要额外安装.

咱们自己也可以实现 “第三方库” 发布出去, 交给别人来使用.

标准库

认识标准库

Python 自身内置了非常丰富的库.

在 Python 官方文档上可以看到这些库的内容.

Python标准库是Python内置的一组模块,包含了大量的常用函数和工具,如文件I/O、网络通信、字符串操作、数据结构、日期和时间处理、正则表达式、多线程等。Python标准库是Python开发者非常常用的一组工具,使用Python标准库可以大大提高开发效率。

Python标准库包含以下模块:

  • 日期和时间(datetime)
  • 数学函数(math)
  • 正则表达式(re)
  • 文件操作(os、io)
  • 网络编程(socket、http)
  • 数据库操作(sqlite3)
  • 多线程编程(threading、queue)
  • 进程管理(subprocess)
  • 图形界面开发(tkinter)
  • XML处理(xml、xml.dom、xml.sax)
  • 邮件处理(smtplib、email)

除了标准库,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)


相关文章
|
17天前
|
调度 开发者 Python
Python中的异步编程:理解asyncio库
在Python的世界里,异步编程是一种高效处理I/O密集型任务的方法。本文将深入探讨Python的asyncio库,它是实现异步编程的核心。我们将从asyncio的基本概念出发,逐步解析事件循环、协程、任务和期货的概念,并通过实例展示如何使用asyncio来编写异步代码。不同于传统的同步编程,异步编程能够让程序在等待I/O操作完成时释放资源去处理其他任务,从而提高程序的整体效率和响应速度。
|
6天前
|
XML 存储 数据库
Python中的xmltodict库
xmltodict是Python中用于处理XML数据的强大库,可将XML数据与Python字典相互转换,适用于Web服务、配置文件读取及数据转换等场景。通过`parse`和`unparse`函数,轻松实现XML与字典间的转换,支持复杂结构和属性处理,并能有效管理错误。此外,还提供了实战案例,展示如何从XML配置文件中读取数据库连接信息并使用。
Python中的xmltodict库
|
10天前
|
机器学习/深度学习 数据挖掘 开发者
Python编程入门:理解基础语法与编写第一个程序
【10月更文挑战第37天】本文旨在为初学者提供Python编程的初步了解,通过简明的语言和直观的例子,引导读者掌握Python的基础语法,并完成一个简单的程序。我们将从变量、数据类型到控制结构,逐步展开讲解,确保即使是编程新手也能轻松跟上。文章末尾附有完整代码示例,供读者参考和实践。
|
13天前
|
数据库 Python
异步编程不再难!Python asyncio库实战,让你的代码流畅如丝!
在编程中,随着应用复杂度的提升,对并发和异步处理的需求日益增长。Python的asyncio库通过async和await关键字,简化了异步编程,使其变得流畅高效。本文将通过实战示例,介绍异步编程的基本概念、如何使用asyncio编写异步代码以及处理多个异步任务的方法,帮助你掌握异步编程技巧,提高代码性能。
49 4
|
13天前
|
API 数据处理 Python
探秘Python并发新世界:asyncio库,让你的代码并发更优雅!
在Python编程中,随着网络应用和数据处理需求的增长,并发编程变得愈发重要。asyncio库作为Python 3.4及以上版本的标准库,以其简洁的API和强大的异步编程能力,成为提升性能和优化资源利用的关键工具。本文介绍了asyncio的基本概念、异步函数的定义与使用、并发控制和资源管理等核心功能,通过具体示例展示了如何高效地编写并发代码。
25 2
|
16天前
|
开发者 Python
Python中__init__.py文件的作用
`__init__.py`文件在Python包管理中扮演着重要角色,通过标识目录为包、初始化包、控制导入行为、支持递归包结构以及定义包的命名空间,`__init__.py`文件为组织和管理Python代码提供了强大支持。理解并正确使用 `__init__.py`文件,可以帮助开发者更好地组织代码,提高代码的可维护性和可读性。
17 2
|
12天前
|
数据采集 数据可视化 数据挖掘
利用Python进行数据分析:Pandas库实战指南
利用Python进行数据分析:Pandas库实战指南
|
19天前
|
文字识别 自然语言处理 API
Python中的文字识别利器:pytesseract库
`pytesseract` 是一个基于 Google Tesseract-OCR 引擎的 Python 库,能够从图像中提取文字,支持多种语言,易于使用且兼容性强。本文介绍了 `pytesseract` 的安装、基本功能、高级特性和实际应用场景,帮助读者快速掌握 OCR 技术。
37 0
|
1月前
|
Python
pip批量安装Python库 requirement.txt 离线环境无互联网环境下pip安装Python库
pip批量安装Python库 requirement.txt 离线环境无互联网环境下pip安装Python库
120 3
|
5月前
|
开发工具 git Python
安装和使用`libnum`是一个用于数字理论函数的Python库
【6月更文挑战第19天】`libnum`是Python的数字理论函数库。安装可通过`git clone`,进入目录后运行`python setup.py install`,也可用`pip install libnum`。示例:使用`int_to_hex`将十进制数42转换为十六进制字符串'2a'。注意,信息可能已过时,应查最新文档以确保准确性。如遇问题,参考GitHub仓库或寻求社区帮助。
117 1
下一篇
无影云桌面