Python:从初学者到专业人士第 4 部分

文件处理:学习读取和写入文件

文件处理对于任何程序员来说都是一项至关重要的技能。每个开发人员都应该能够访问外部来源的数据并与之交互,并实现计算和存储。

文件用于在磁盘上存储数据。它们可以包含文本、数字或二进制数据。在 python 中,我们使用内置函数和方法来处理文件。

要打开文件,我们使用 open() 函数。它需要两个主要论点:

文件路径(名称)模式(读、写、追加等)

常用模式

‘r’:读取(默认)’w’:写入(覆盖现有内容)’a’:追加(添加到现有内容)’x’:独占创建(如果文件已存在则失败)’b’:二进制模式’+’:开放更新(阅读和写作)

示例:

file = open("scofield.txt", "w")

在这个例子中,我们创建了一个名为 file 的变量,我们说它应该调用 scofield.txt,其中我们附加“w”来覆盖其中写入的任何内容。

立即学习“Python免费学习笔记(深入)”;

写入文件
要写入文件,请使用 write() 方法。

 file = open("scofield.txt", "w") file.write("hello, world!") file.close()

完成后关闭文件以释放系统资源非常重要。更好的做法是使用 with 语句,它会自动关闭文件。

Python:从初学者到专业人士第 4 部分

 with open("scofiedl.txt", "w") as file:    file.write("hello, world!")

覆盖里面的内容后,我们编写了上面的代码,但使其更短,使用 with open 命令关闭 scofield.txt。

从文件中读取
您可以使用多种方法来读取文件。

read(): reads the entire filereadline(): reads a single linereadlines(): reads all lines into a list

示例:

with open("scofield.txt", "r") as file:    content = file.read()    print(content)

Python:从初学者到专业人士第 4 部分

附加到文件
要将内容添加到现有文件而不覆盖,请使用追加模式:

with open("scofield.txt", "a") as file:    file.write("nthis is a new line.")

您可以添加到现有文件,而不是总是覆盖现有文件,如果您有一个正在进行的项目并希望访问以前的工作,这是一个很好的方法。

Python:从初学者到专业人士第 4 部分

为了充分理解文件处理的下一个方面,我们必须暂停学习并深入研究模块和库。

python 如此通用和强大的关键功能之一是其广泛的模块和库生态系统。这些工具允许您扩展 python 的功能,使复杂的任务变得更简单,并使您能够编写更高效、更强大的程序。

什么是模块和库?
从本质上讲,python 中的模块只是一个包含 python 代码的文件。它可以定义可在程序中使用的函数、类和变量。另一方面,库是模块的集合。将模块视为单独的工具,而库是包含多个相关工具的工具箱。

模块和库的主要目的是促进代码可重用性。您可以使用预先编写的、经过测试的代码来执行常见任务,而不是从头开始编写所有内容。这可以节省时间并减少程序出错的机会。

内置模块
python 附带了一组内置模块,它们是标准库的一部分。这些模块在每个 python 安装中都可用,提供广泛的开箱即用功能。让我们探讨几个例子。

“随机”模块

“随机”模块用于生成随机数。使用方法如下:

import random# generate a random integer between 1 and 10random_number = random.randint(1, 10)print(random_number)# choose a random item from a listfruits = ["apple", "banana", "cherry"]random_fruit = random.choice(fruits)print(random_fruit)

在这个例子中,我们首先导入 random 模块。然后我们使用它的 randint 函数生成一个随机整数,并使用它的 ‘choice’ 函数从列表中选择一个随机项目。

Python:从初学者到专业人士第 4 部分

“日期时间”模块:

“datetime”模块提供了处理日期和时间的类:

import datetime# get the current date and timecurrent_time = datetime.datetime.now()print(current_time)# create a specific datebirthday = datetime.date(1990, 5, 15)print(birthday)

这里,我们使用 datetime 模块来获取当前日期和时间,并创建一个特定的日期。

Python:从初学者到专业人士第 4 部分

“数学”模块

“数学”模块提供数学函数。

import math# calculate the square root of a numbersqrt_of_16 = math.sqrt(16)print(sqrt_of_16)# calculate the sine of an angle (in radians)sine_of_pi_over_2 = math.sin(math.pi / 2)print(sine_of_pi_over_2)

此示例演示了使用“math”模块进行数学计算。

导入模块
python 中有多种导入模块的方法:

导入整个模块

import randomrandom_number = random.randint(1, 10)

从模块导入特定功能

from random import randintrandom_number = randint(1, 10)

从模块导入所有函数(谨慎使用)

from random import *random_number = randint(1, 10)

导入带有别名的模块

python 导入随机作为 rnd random_number = rnd.randint(1, 10)## python 外部库

虽然标准库非常广泛,但 python 的真正力量在于其庞大的第三方库生态系统。这些库涵盖了从 web 开发到数据分析和机器学习的各种功能。

要使用外部库,首先需要安装它们。这通常是使用 python 的包安装程序 pip 完成的。这是一个使用流行的“requests”库发出 http 请求的示例。

安装库

pip 安装请求

Python:从初学者到专业人士第 4 部分

在代码中使用该库

import requestsresponse = requests.get('https://api.github.com')print(response.status_code)print(response.json())

此代码向 github api 发送 get 请求并打印响应状态和内容。

Python:从初学者到专业人士第 4 部分

我们的回答是200,这意味着成功;我们能够连接到服务器。

Python:从初学者到专业人士第 4 部分

创建您自己的模块
随着项目的增长,您可能希望将代码组织成模块。创建模块就像将 python 代码保存在 .py 文件中一样简单。例如,让我们创建一个名为“write.py”的模块

关键是确保所有文件都在一个目录中,以便 python 可以轻松地根据名称跟踪文件。

 with open("scofield.txt", "w") as file:    content = file.write("hello welcome to school")

现在,您可以在另一个python文件中使用这个模块,因此我们将其导入到我创建的名为read.py的新文件中,只要它们位于同一目录中即可。

import writewith open("scofield.txt", "r") as file:    filenew = file.read()    print(filenew)

我们的结果将输出我们在 write.py 中设置的写入命令。

Python:从初学者到专业人士第 4 部分

python 路径

导入模块时,python 会在多个位置查找它,统称为 python 路径。这包括.

包含您正在运行的脚本的目录python 标准库pythonpath 环境变量中列出的目录安装第三方库的site-packages目录

了解python路径可以帮助您解决导入问题并有效地组织您的项目。

最佳实践

仅导入您需要的内容:不要导入整个模块,而是尽可能导入特定的函数或类。使用有意义的别名:如果您使用别名,请确保它们清晰且具有描述性。保持导入有序:将导入分组在文件顶部,通常按照标准库导入、第三方导入、然后本地导入的顺序进行。谨慎对待“from module import***”**:这可能会导致命名冲突并使您的代码更难理解。使用虚拟环境:在处理不同的项目时,使用虚拟环境来管理依赖关系,避免不同版本的库之间的冲突。

模块和库是 python 编程的基础。它们允许您利用现有代码、扩展 python 的功能并有效地组织您的代码。

现在您了解了导入,让我们看看它如何与文件处理一起工作。

import osfile_path = os.path.join("folder", "scofield_fiel1.txt")with open(file_path, "w") as file:    file.write("success comes with patience and commitment")

首先,我们导入 os 模块。该模块提供了一种使用与操作系统相关的功能的方法,例如创建和删除目录,获取环境变量,或者在我们的例子中,使用文件路径。通过导入“os”,我们可以访问无论您使用的是 windows、macos 还是 linux 都可以使用的工具。

接下来,我们使用 os.path.join() 创建文件路径。此功能非常有用,因为它为您的操作系统创建了正确的路径。

在 windows 上,它可能会生成“folderexample.txt”,而在基于 unix 的系统上,它将创建 “folder/scofield_file1.txt”。这个小细节使您的代码更具可移植性,并且在不同系统上运行时不太可能损坏。
变量“file_path”现在包含名为“folder”的文件夹内名为“example.txt”的文件的正确路径。

如上所述,with 语句允许 python 在我们写完文件后关闭文件。

open()函数用于打开文件。我们向它传递两个参数:我们的 file_path 和模式“w”。 “w”模式代表写入模式,如果文件不存在则创建该文件,如果存在则覆盖该文件。其他常见模式包括“r”表示读取和“a”表示追加。

最后,我们使用 write() 方法将一些文本放入文件中。文本“using os.path.join for file paths”将被写入该文件,表明我们已使用适用于任何操作系统的路径成功创建并写入文件。

如果你喜欢我的工作并且想帮助我继续删除这样的内容,请给我买杯咖啡。

如果您觉得我们的帖子令人兴奋,请在 learnhub 博客上找到更多令人兴奋的帖子;我们编写从云计算到前端开发、网络安全、人工智能和区块链的所有技术。

资源

开始使用 foliumvisual studio code 的 20 个基本 python 扩展使用python进行网页抓取和数据提取python 入门使用 folium 和 python 创建交互式地图

以上就是Python:从初学者到专业人士第 4 部分的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1348135.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 11:46:11
下一篇 2025年12月13日 11:46:27

相关推荐

  • 如何解决本地图片在使用 mask JS 库时出现的跨域错误?

    如何跨越localhost使用本地图片? 问题: 在本地使用mask js库时,引入本地图片会报跨域错误。 解决方案: 要解决此问题,需要使用本地服务器启动文件,以http或https协议访问图片,而不是使用file://协议。例如: python -m http.server 8000 然后,可以…

    2025年12月24日
    200
  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • 使用 Mask 导入本地图片时,如何解决跨域问题?

    跨域疑难:如何解决 mask 引入本地图片产生的跨域问题? 在使用 mask 导入本地图片时,你可能会遇到令人沮丧的跨域错误。为什么会出现跨域问题呢?让我们深入了解一下: mask 框架假设你以 http(s) 协议加载你的 html 文件,而当使用 file:// 协议打开本地文件时,就会产生跨域…

    2025年12月24日
    200
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 有哪些美观的开源数字大屏驾驶舱框架?

    开源数字大屏驾驶舱框架推荐 问题:有哪些美观的开源数字大屏驾驶舱框架? 答案: 资源包 [弗若恩智能大屏驾驶舱开发资源包](https://www.fanruan.com/resource/152) 软件 [弗若恩报表 – 数字大屏可视化组件](https://www.fanruan.c…

    2025年12月24日
    000
  • 网站底部如何实现飘彩带效果?

    网站底部飘彩带效果的 js 库实现 许多网站都会在特殊节日或活动中添加一些趣味性的视觉效果,例如点击按钮后散发的五彩缤纷的彩带。对于一个特定的网站来说,其飘彩带效果的实现方式可能有以下几个方面: 以 https://dub.sh/ 网站为例,它底部按钮点击后的彩带效果是由 javascript 库实…

    2025年12月24日
    000
  • 网站彩带效果背后是哪个JS库?

    网站彩带效果背后是哪个js库? 当你访问某些网站时,点击按钮后,屏幕上会飘出五颜六色的彩带,营造出庆祝的氛围。这些效果是通过使用javascript库实现的。 问题: 哪个javascript库能够实现网站上点击按钮散发彩带的效果? 答案: 根据给定网站的源代码分析: 可以发现,该网站使用了以下js…

    好文分享 2025年12月24日
    100
  • 产品预览卡项目

    这个项目最初是来自 Frontend Mentor 的挑战,旨在使用 HTML 和 CSS 创建响应式产品预览卡。最初的任务是设计一张具有视觉吸引力和功能性的产品卡,能够无缝适应各种屏幕尺寸。这涉及使用 CSS 媒体查询来确保布局在不同设备上保持一致且用户友好。产品卡包含产品图像、标签、标题、描述和…

    2025年12月24日
    100

发表回复

登录后才能评论
关注微信