跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
Python算法

Python 标准库与第三方库实战:日期处理与 Excel 操作

综述由AI生成Python 标准库包含内置函数、文本处理、时间日期等模块,通过 import 导入使用。第三方库需通过 pip 安装,如 qrcode 生成二维码、xlrd 操作 Excel。文章演示了日期计算、字符串翻转、文件查找及 Excel 数据分析等实战案例,涵盖标准库 datetime/os 与第三方库 qrcode/xlrd 的应用方法。

数字游民发布于 2026/2/5更新于 2026/5/288.2K 浏览
Python 标准库与第三方库实战:日期处理与 Excel 操作

Python 标准库与第三方库实战

1. 使用库:标准库和第三方库

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

荀子曰:'君子性非异也,善假于物也'。

一个编程语言能不能流行起来,一方面取决于语法是否简单方便容易学习,一方面取决于生态是否完备。所谓的'生态'指的就是语言是否有足够丰富的库,来应对各种各样的场景。

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

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

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

2. 标准库

2.1 认识标准库

2.1.1 理论

Python 自身内置了非常丰富的库,在 Python 官方文档 上可以看到这些库的内容。

简单来说,主要是这些部分:

  • 内置函数 (如 print, input 等) 及内置类型 (针对 int, str, bool, list, dict 等类型内置的操作)
  • 文本处理
  • 时间日期
  • 数学计算
  • 文件目录
  • 数据存储 (操作数据库,数据序列化等)
  • 加密解密
  • 操作系统相关
  • 并发编程相关 (多进程,多线程,协程,异步等)
  • 网络编程相关
  • 多媒体相关 (音频处理,视频处理等)
  • 图形化界面相关

我们不需要把这些库的内容都背下来,只要大概知道里面有啥,需要用的时候能够找到即可。

2.2 使用 import 导入模块

2.2.1 理论

使用 import 可以导入标准库的一个 模块。

import[模块名]

所谓'模块',其实就是一个单独的 .py 文件。

使用 import 语句可以把这个外部的 .py 文件导入到当前 .py 文件中,并执行其中的代码。

2.2.2 最佳实践

最佳实践等到后面我们使用起来就知道啦。

2.3 代码示例:日期计算

2.3.1 理论

输入任意的两个日期,计算两个日期之间隔了多少天。

  • 使用 import 语句导入标准库的 datetime 模块。
  • 使用 datetime.datetime 构造两个日期,参数使用 年/月/日 这样的格式。
  • 两个日期对象相减,即可得到日期的差值。
import datetime
date1 = datetime.datetime(2012, 2, 14)
date2 = datetime.datetime(2022, 7, )
(date2 - date1)
12
print

图片

关于 datetime 的更多操作,可以参考官方文档。

2.3.2 最佳实践
# 代码案例:日期计算器(日期之间作差)
# datetime
# import datetime # (import) 导入对应的模块
# # 先构造 datetime 变量
# # datetime.datetime(模块名。类型名)
# date1 = datetime.datetime(2006, 12, 14)
# date2 = datetime.datetime(2025, 12, 14)
# # 也可以通过关键字参数传
# # date1 = datetime.datetime(year=2025, month=12, day=14) # 更加直观
# print(date2 - date1) # 两种相减可得出相差多久
# # 这样写还有点别扭,我们可以直接这样写
from datetime import datetime # 变成从 datetime 模块 import 一个 datetime 类型
# # 通过这样的改变,让我们后续无需再写 [datetime.] --> [模块名.] 的方式——改进的写法
# # 先构造 datetime 变量
date1 = datetime(2006, 12, 14)
date2 = datetime(2025, 12, 14)
print(date2 - date1) # 结果完全一样

# 还有一种写法:既能在这行代码中知道模块名是什么,也能体现出后续构造的对象是什么类型
# 比较直观
import datetime as dt # 还是 datetime 模块导入,但是给 datetime 取了一个别名 dt,通过 dt 代表了 datetime
# 通过这样的改变,让我们后续无需再写 [datetime.] --> [模块名.] 的方式——改进的写法
# 先构造 datetime 变量
date1 = dt.datetime(2006, 12, 14)
date2 = dt.datetime(2025, 12, 14)
print(date2 - date1) # 结果完全一样
2.3.3 英文文档看不懂的问题

像上面这样,Python 文档是国外的网站,搜索起来太慢了,等不及怎么办?

我们可以下载 Python 时候就顺带下载的离线模式的 Python 文档,可以快速查找,缺点就是:这个离线文档全是英文!

2.4 代码示例:字符串操作

字符串是 Python 的内置类型,字符串的很多方法不需要导入额外的模块,即可直接使用。

2.4.1 剑指 offer 58:翻转单词顺序

参考题目:剑指 Offer 58:翻转单词顺序

2.4.1.1 理论

输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串'I am a student.',则输出'student.aamI'。

  • 使用 str 的 split 方法进行字符串切分,指定空格为分隔符,返回结果是一个列表。
  • 使用列表的 reverse 方法进行逆序。
  • 使用 str 的 join 方法进行字符串拼接——把列表中的内容进行合并。
2.4.1.2 答案参考
def reverseWords(s):
    tokens = s.split()
    tokens.reverse()
    return ' '.join(tokens)

print(reverseWords('I am a student.'))
2.4.1.3 最佳实践
# 代码示例:字符串操作
# 代码案例:单词逆序(剑指 offer 中的题目)
# 题目:怎样区分的单词?根据空格来分割
# 在 Python 中,思路是这样的:
# 1、针对上述字符串,使用空格进行划分
# 字符串 split 方法,可以指定分隔符,把字符串分成多个部分,放到一个 list 里
# 2、针对刚才的切分结果列表,进行逆序 (reverse 方法)
# 3、再把逆序后的列表,组合起来 (join,并且可以在组合指定分隔符为 1 个空格)
def reverseWords(s: str):
    # s:[类型声明],这样下面就有提示了(变量有了类型声明之后)
    tokens = s.split(' ') # 没有代码提示:是因为 Python 是动态类型的语言,所以我们写 s 的时候,
    # 其实 Pycharm 是不知道 s 是什么类型的,不知道是啥类型,也就不知道有哪些方法,
    # 所以 s.spilt 到底能不能调用,以及有没有其它方法,这是不好确定的
    tokens.reverse() # 逆序
    return ' '.join(tokens) # 借助空格分隔符,把这里的字符串重新拼接成一个更长的字符串

# 输入一个字符串,运行程序
print(reverseWords("I am a student."))
2.4.2 leetcode 796:旋转字符串

参考题目:LeetCode 796:旋转字符串

2.4.2.1 理论

给定两个字符串,s 和 goal。如果在若干次旋转操作之后,s 能变成 goal,那么返回 true。 s 的旋转操作就是将 s 最左边的字符移动到最右边。 例如,若 s='abcde',在旋转一次之后结果就是 'bcdea'。

  • 使用 len 方法求字符串的长度。如果长度不相同,则一定不能旋转得到。
  • 将 s 和自己进行拼接,然后直接使用 in 方法来判定 goal 是否是 s+s 的子串。
2.4.2.2 参考答案
def rotateString(s, goal):
    return len(s) == len(goal) and goal in s + s

print(rotateString('abcde', 'cdeab'))
2.4.2.3 最佳实践
# 代码案例:旋转字符串
# 题目要求
# 如果在若干次旋转操作之后,s 能变成 goal,那么返回 true
# s = "abcde" "bcdea" "cdead" "deabc" "eabcd"(s 通过旋转能得到的内容)
# 把最左侧的字符,给放到最右侧去!
# s + s => "abcdeabcde" # 每个旋转后得到的字符串都可以在这样一个大字符串中找到
def rotateString(s, goal):
    if len(s) != len(goal):
        return False
    return goal in (s + s) # in 判断某个字符串是否是另外一个字符串的子串

print(rotateString("abcde", "cdeab"))
print(rotateString("abcde", "edcba"))
2.4.3 leetcode 2255:统计是给定字符串前缀的字符串数目

参考题目:LeetCode 2255:统计是给定字符串前缀的字符串数目

2.4.3.1 理论

给你一个字符串数组 words 和一个字符串 s,其中 words[i] 和 s 只包含小写英文字母。

请你返回 words 中是字符串 s 前缀的字符串数目。

一个字符串的前缀是出现在字符串开头的子字符串。子字符串是一个字符串中的连续一段字符序列。

  • 依次遍历 words 中的字符串。
  • 直接使用字符串的 startswith 方法即可判定当前字符串是否是 s 的前缀。
2.4.3.2 参考答案
def countPrefixes(words, s):
    res = 0 # 符合要求字符串个数
    for word in words:
        if s.startswith(word):
            res += 1
    return res

print(countPrefixes(["a","b","c","ab","bc","abc"],"abc"))
2.4.3.3 最佳实践
# 代码案例:统计字符串前缀
# 遍历 words,取出每个字符串,判定当前这个字符串是否是 s 的前缀即可 (s 是否是以这个字符串开题的)
def countPrefixes(words:list, s:str):
    count = 0
    for word in words:
        if s.startswith(word): # 使用 in 操作可以判断 word 是不是 s 的一部分
            # s 是以 word 开头
            count += 1
    return count # 注意缩进

print(countPrefixes(['a','b','c','ab','bc','abc'],'abc'))
print(countPrefixes(['a','a'],'aa'))
2.4.4 其它字符串操作

关于字符串的更多操作,参考官方文档:查看文档中的字符串操作。

2.5 代码示例:文件查找工具

2.5.1 理论

指定一个待搜索路径,同时指定一个待搜索的关键字。

在待搜索路径中查找是否文件名中包含这个关键字——

  • 使用 os.walk 即可实现目录的递归遍历。
  • os.walk 返回一个三元组,分别是 当前路径,当前路径下包含的目录名(多个),当前路径下包含的文件名(多个)
import os
inputPath = input('请输入待搜索路径:')
pattern = input('请输入待搜索关键词:')
for dirpath, dirnames, filenames in os.walk(inputPath):
    for f in filenames:
        if pattern in f:
            print(f'{dirpath}/{f}')

图片

2.5.2 最佳实践
# 文件搜索工具
# 很多目录,很多文件,想找到某个文件,就不太容易
# 文件搜索工具——如 everything
# 实现文件查找工具
# 输入要查找的路径,输入要搜索的文件名(一部分)
# 自动地在指定的路径进行查找
# import os
# inputPath = input('请输入要搜索的路径:')
# pattern = input('请输入要搜索的关键词:')
# 递归查找,遇到子目录,就进到目录里面进行查找
# OS.walk(OS:操作系统),只需要使用简单的循环就可以完成递归遍历的过程,就不必手写递归代码了
# for dirpath,dirnames,filenames in os.walk(inputPath):
#     print('----------------------------')
#     print(f'dirpath = {dirpath}')
#     print('dirnames:')
#     for name in dirnames:
#         print(name)
#     print('filename:')
#     for name in filenames:
#         print(name)
# dirpath: 遍历到当前位置,对应的路径是啥
# dirnames: 当前目录下,都有哪些目录,是一个列表,可以包含多个目录名
# filenames: 当前目录下,都有哪些文件名,是一个列表,可以包含多个文件名
# os.walk: os.walk 每次调用都能自动的去针对子目录进行递归的操作,只需要使用上述循环就可以把所有的路径都获取出来
# 正式实现一下这里的功能
import os
inputPath = input('请输入要搜索的路径:')
pattern = input('请输入要搜索的关键词:')
for dirpath,_,filenames in os.walk(inputPath):
    for f in filenames:
        if pattern in f:
            print(f'{dirpath}/{f}')
# 这里只是一个简单粗暴的遍历,比不了 everything,不算特别高效

图片

图片

2.5.3 其它 os 模块操作

关于 os 模块的更多操作,参考官方文档:文档中的更多 os 操作。

3. 第三方库

3.1 认识第三方库

第三方库就是别人已经实现好了的库,我们可以拿过来直接使用。

虽然标准库已经很强大了,但是终究是有限的;而第三方库可以视为集合了全世界 Python 程序员的智慧,可以说是几乎无穷无尽。

当我们遇到一个需求场景的时候,如何知道,该使用哪个第三方库呢?

这时候就需要用到 PyPI 等网站。

当我们确定了该使用哪个第三方库之后,就可以使用 pip 来安装第三方库了。

3.2 使用 pip

3.2.1 理论

pip 是 Python 内置的 包管理器。

所谓 包管理器 就类似于我们平时使用的手机 app 应用商店一样。

第三方库有很多,是不同的人,不同的组织实现的。为了方便大家整理,Python 官方提供了一个网站 PyPI,来收集第三方库。

其他大佬写好的第三方库也会申请上传到 PyPI 上。 这个时候就可以方便的使用 pip 工具来下载 PyPI 上的库了。

pip 在我们安装 Python 的时候就已经内置了,无需额外安装。

pip 是一个可执行程序,就在 Python 的安装目录中。 打开 cmd,直接输入 pip,如果显示以下帮助信息,说明 pip 已经准备就绪。

如果最开始按照要求在安装 Python 的时候勾选了这个选项,那么 pip 就是默认可用的。

如果 pip 不能使用,说明安装时没有勾选这个选项。 如果提示:

'pip'不是内部或外部命令,也不是可运行的程序 或批处理文件。

则说明没有正确的把 pip 加入到 PATH 中,可以手动把 pip 所在的路径加入到 PATH 环境变量中。 或者卸载重装 Python,记得勾上上述选项,也许是更简单的办法。

使用以下命令,即可安装第三方库——

pip install [库名]

注意: 这个命令需要从网络上下载,使用时要保证网络畅通。

安装成功后,即可使用 import 导入相关模块,即可进行使用。

注意:如果使用 pip 安装完第三方库之后,在 PyCharm 中仍然提示找不到对应的模块,则检查 Settings->Project->PythonInterpreter,看当前 Python 解释器设置的是否正确(如果一个机器上安装了多个版本的 Python,容易出现这种情况)。

3.2.2 最佳实践
# 第三方库(规模远超标准库)
# 认识第三方库
# 代码案例:pip 的使用
# pip(Python 内置的包管理器)
# 手机 app,app 其实是来自于不同的厂商——应用商店(下载程序不必找官网啦)
# Python 的第三方库也是如此!
# Python 官方搞了一个网址 pypi,把各种第三方库给收集起来了!又提供了一个 pip 工具
# 使用 pip 就能直接从 pypi 上面下载你想要的第三方库
# pip 我们视为是 Python 世界中的应用商店
# 安装 Python 的时候已经自动地把 pip 装好了,我们直接就能使用!
# 如何使用 pip 呢?pip 是一个命令行程序
# 很多语言都有依赖第三方库

图片

图片

pip 效果如下所示,是不是蛮像应用商店的——

图片

像上面这样,说明 pip 已经安装了,可以使用。

3.3 代码示例:生成二维码

3.3.1 通过搜索引擎,确定使用哪个库

得到情报,qrcode 这个库,可以用来生成二维码。

3.3.2 查看 qrcode 文档

在 PyPI 上搜索 qrcode,点击则进入 qrcode 的详情页。

文档开头描述了如何安装 qrcode。 页面中央位置描述了 qrcode 库的使用方法。

3.3.3 使用 pip 安装
pip install qrcode[pil]

注意: pip 安装的时候可能会有警告,提示使用的 pip 版本太低,这个警告我们不必处理,不影响我们正常使用。

3.3.4 编写代码

按照文档给出的示例,模仿一段代码:

import qrcode
img = qrcode.make('艾莉丝努力练剑')
img.save('qrcode.png')

运行完毕后,得到结果如下:

图片

使用微信或者其他工具扫码,即可看到二维码内容。

所谓二维码,本质上就是使用黑白点阵表示一个字符串。

我们日常使用的二维码内部一般是一个 URL,扫码后会自动跳转到对应的地址,从而打开一个网页。

图片

3.3.5 最佳实践
# 二维码生成工具
# 二维码本质上就是一段字符串
# 我们可以把任意的字符串,制作成一个二维码图片
# 生活中使用的二维码,更多的是一个 URL(网址)
# 标准库里面能不能干这件事情?好像没有这个功能
# 这时候就要看第三方库了——搜索引擎——qrcode
import qrcode
img = qrcode.make('艾莉丝努力练剑!')
# img = qrcode.make('艾莉丝努力练剑!秃秃,新的一周,继续加油吧!艾莉丝会一直支持你哒!')
img.save('qrcode.png')

3.4 代码示例:操作 excel

3.4.1 理论

读取 excel 可以使用 xlrd 模块。文档地址:xlrd

修改 excel 可以使用 xlwt 模块。文档地址:xlwt

此处以 xlrd 为例,演示 excel 的基本操作。

3.4.2 需求

需求 有如下 excel 表格 d:/test.xlsx:

图片

求 100 班的同学的平均分。

虽然 excel 自身支持很强大的功能,也可以求和,求平均值,但是如果是稍微复杂的需求,操作起来可能就没那么方便了。

3.4.3 操作
3.4.3.1 安装 xlrd
pip install xlrd==1.2.0

注意: 此处要指定版本号安装,如果不指定版本号,则安装最新版,最新版里删除了对 xlsx 格式文件的支持。

3.4.3.2 编写代码
  • 使用 open_workbook 方法打开一个 excel 文件。
  • 使用 xlsx.sheet_by_index(0) 获取到 0 号标签页。
  • 使用 table.nrows 获取到表格的行数。
  • 使用 table.cell_value(row, col) 获取到表格中 row, col 位置的元素值。
import xlrd
# 1. 打开 xlsx 文件
xlsx = xlrd.open_workbook('d:/test.xlsx')
# 2. 获取 0 号标签页。(当前只有一个标签页)
table = xlsx.sheet_by_index(0)
# 3. 获取总行数
nrows = table.nrows
# 4. 遍历数据
count = 0
total = 0
for i in range(1, nrows):
    # 使用 cell_value(row, col) 获取到指定坐标单元格的值.
    classId = table.cell_value(i, 1)
    if classId == 101:
        total += table.cell_value(i, 2)
        count += 1
print(f'平均分:{total / count}')
3.4.4 最佳实践

图片

# 代码案例:操作 excel
# 操作 excel
import xlrd
# 1、先打开 xlsx 文件
xlsx = xlrd.open_workbook('C:/Users/18106/Desktop/比特课程学习课件/Python/Python:Excel 操作.xlsx')
# 2、获取到指定的标签页
table = xlsx.sheet_by_index(0)
# 3、获取到表格中有多少行
nrows = table.nrows
# 4、进行循环统计操作
total = 0
count = 0
for i in range(1, nrows):
    # 拿到当前同学的班级
classID = table.cell_value(i, 1)
if classID == 100:
    total += table.cell_value(i, 2)
    count += 1
print(f'平均分:{total / count}')

目录

  1. Python 标准库与第三方库实战
  2. 1. 使用库:标准库和第三方库
  3. 2. 标准库
  4. 2.1 认识标准库
  5. 2.1.1 理论
  6. 2.2 使用 import 导入模块
  7. 2.2.1 理论
  8. 2.2.2 最佳实践
  9. 2.3 代码示例:日期计算
  10. 2.3.1 理论
  11. 2.3.2 最佳实践
  12. 代码案例:日期计算器(日期之间作差)
  13. datetime
  14. import datetime # (import) 导入对应的模块
  15. # 先构造 datetime 变量
  16. # datetime.datetime(模块名。类型名)
  17. date1 = datetime.datetime(2006, 12, 14)
  18. date2 = datetime.datetime(2025, 12, 14)
  19. # 也可以通过关键字参数传
  20. # date1 = datetime.datetime(year=2025, month=12, day=14) # 更加直观
  21. print(date2 - date1) # 两种相减可得出相差多久
  22. # 这样写还有点别扭,我们可以直接这样写
  23. # 通过这样的改变,让我们后续无需再写 [datetime.] --> [模块名.] 的方式——改进的写法
  24. # 先构造 datetime 变量
  25. 还有一种写法:既能在这行代码中知道模块名是什么,也能体现出后续构造的对象是什么类型
  26. 比较直观
  27. 通过这样的改变,让我们后续无需再写 [datetime.] --> [模块名.] 的方式——改进的写法
  28. 先构造 datetime 变量
  29. 2.3.3 英文文档看不懂的问题
  30. 2.4 代码示例:字符串操作
  31. 2.4.1 剑指 offer 58:翻转单词顺序
  32. 2.4.1.1 理论
  33. 2.4.1.2 答案参考
  34. 2.4.1.3 最佳实践
  35. 代码示例:字符串操作
  36. 代码案例:单词逆序(剑指 offer 中的题目)
  37. 题目:怎样区分的单词?根据空格来分割
  38. 在 Python 中,思路是这样的:
  39. 1、针对上述字符串,使用空格进行划分
  40. 字符串 split 方法,可以指定分隔符,把字符串分成多个部分,放到一个 list 里
  41. 2、针对刚才的切分结果列表,进行逆序 (reverse 方法)
  42. 3、再把逆序后的列表,组合起来 (join,并且可以在组合指定分隔符为 1 个空格)
  43. 输入一个字符串,运行程序
  44. 2.4.2 leetcode 796:旋转字符串
  45. 2.4.2.1 理论
  46. 2.4.2.2 参考答案
  47. 2.4.2.3 最佳实践
  48. 代码案例:旋转字符串
  49. 题目要求
  50. 如果在若干次旋转操作之后,s 能变成 goal,那么返回 true
  51. s = "abcde" "bcdea" "cdead" "deabc" "eabcd"(s 通过旋转能得到的内容)
  52. 把最左侧的字符,给放到最右侧去!
  53. s + s => "abcdeabcde" # 每个旋转后得到的字符串都可以在这样一个大字符串中找到
  54. 2.4.3 leetcode 2255:统计是给定字符串前缀的字符串数目
  55. 2.4.3.1 理论
  56. 2.4.3.2 参考答案
  57. 2.4.3.3 最佳实践
  58. 代码案例:统计字符串前缀
  59. 遍历 words,取出每个字符串,判定当前这个字符串是否是 s 的前缀即可 (s 是否是以这个字符串开题的)
  60. 2.4.4 其它字符串操作
  61. 2.5 代码示例:文件查找工具
  62. 2.5.1 理论
  63. 2.5.2 最佳实践
  64. 文件搜索工具
  65. 很多目录,很多文件,想找到某个文件,就不太容易
  66. 文件搜索工具——如 everything
  67. 实现文件查找工具
  68. 输入要查找的路径,输入要搜索的文件名(一部分)
  69. 自动地在指定的路径进行查找
  70. import os
  71. inputPath = input('请输入要搜索的路径:')
  72. pattern = input('请输入要搜索的关键词:')
  73. 递归查找,遇到子目录,就进到目录里面进行查找
  74. OS.walk(OS:操作系统),只需要使用简单的循环就可以完成递归遍历的过程,就不必手写递归代码了
  75. for dirpath,dirnames,filenames in os.walk(inputPath):
  76. print('----------------------------')
  77. print(f'dirpath = {dirpath}')
  78. print('dirnames:')
  79. for name in dirnames:
  80. print(name)
  81. print('filename:')
  82. for name in filenames:
  83. print(name)
  84. dirpath: 遍历到当前位置,对应的路径是啥
  85. dirnames: 当前目录下,都有哪些目录,是一个列表,可以包含多个目录名
  86. filenames: 当前目录下,都有哪些文件名,是一个列表,可以包含多个文件名
  87. os.walk: os.walk 每次调用都能自动的去针对子目录进行递归的操作,只需要使用上述循环就可以把所有的路径都获取出来
  88. 正式实现一下这里的功能
  89. 这里只是一个简单粗暴的遍历,比不了 everything,不算特别高效
  90. 2.5.3 其它 os 模块操作
  91. 3. 第三方库
  92. 3.1 认识第三方库
  93. 3.2 使用 pip
  94. 3.2.1 理论
  95. 3.2.2 最佳实践
  96. 第三方库(规模远超标准库)
  97. 认识第三方库
  98. 代码案例:pip 的使用
  99. pip(Python 内置的包管理器)
  100. 手机 app,app 其实是来自于不同的厂商——应用商店(下载程序不必找官网啦)
  101. Python 的第三方库也是如此!
  102. Python 官方搞了一个网址 pypi,把各种第三方库给收集起来了!又提供了一个 pip 工具
  103. 使用 pip 就能直接从 pypi 上面下载你想要的第三方库
  104. pip 我们视为是 Python 世界中的应用商店
  105. 安装 Python 的时候已经自动地把 pip 装好了,我们直接就能使用!
  106. 如何使用 pip 呢?pip 是一个命令行程序
  107. 很多语言都有依赖第三方库
  108. 3.3 代码示例:生成二维码
  109. 3.3.1 通过搜索引擎,确定使用哪个库
  110. 3.3.2 查看 qrcode 文档
  111. 3.3.3 使用 pip 安装
  112. 3.3.4 编写代码
  113. 3.3.5 最佳实践
  114. 二维码生成工具
  115. 二维码本质上就是一段字符串
  116. 我们可以把任意的字符串,制作成一个二维码图片
  117. 生活中使用的二维码,更多的是一个 URL(网址)
  118. 标准库里面能不能干这件事情?好像没有这个功能
  119. 这时候就要看第三方库了——搜索引擎——qrcode
  120. img = qrcode.make('艾莉丝努力练剑!秃秃,新的一周,继续加油吧!艾莉丝会一直支持你哒!')
  121. 3.4 代码示例:操作 excel
  122. 3.4.1 理论
  123. 3.4.2 需求
  124. 3.4.3 操作
  125. 3.4.3.1 安装 xlrd
  126. 3.4.3.2 编写代码
  127. 1. 打开 xlsx 文件
  128. 2. 获取 0 号标签页。(当前只有一个标签页)
  129. 3. 获取总行数
  130. 4. 遍历数据
  131. 3.4.4 最佳实践
  132. 代码案例:操作 excel
  133. 操作 excel
  134. 1、先打开 xlsx 文件
  135. 2、获取到指定的标签页
  136. 3、获取到表格中有多少行
  137. 4、进行循环统计操作
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • 基于 WebView2 的轻量级 Web 桌面应用打包方案
  • QClaw 本地化 AI 个人助手平台完全指南
  • ToDesk ToClaw:基于 OpenClaw 的零门槛 AI 桌面自动化方案
  • OpenClaw 开源 AI Agent 框架解析
  • HTML 基础标签与简易网页制作实战
深度学习模型评估:核心指标与最佳实践
  • 鸿蒙 Share Kit 隔空传送功能开发详解
  • 2024 AI 图像生成项目精选
  • 知识图谱基础概念详解:实体、关系与属性构建指南
  • 基于协同过滤的招聘信息推荐系统:Django 架构与爬虫实践
  • C++ 类与对象进阶:初始化列表、静态成员与编译器优化实战
  • 37 岁程序员职场危机应对与 Android 高级开发技能梳理
  • OpenClaw 安装与飞书机器人接入完整教程
  • Flutter 集成 AI 大模型 API 实战:构建多平台通用智能助手应用
  • Spring Integration Kafka XML 配置示例
  • WebUI 界面交互优化:手机检测系统上传失败重试机制与用户体验改进
  • 2025 年 AI 模型 API 中转与聚合平台横评
  • 大模型入门教程:核心优势与学习路径指南
  • Claude Skills 技能机制详解与实战指南
  • MySQL 基本查询实战:增删改查与聚合分组详解
  • 相关免费在线工具

    • 加密/解密文本

      使用加密算法(如AES、TripleDES、Rabbit或RC4)加密和解密文本明文。 在线工具,加密/解密文本在线工具,online

    • Gemini 图片去水印

      基于开源反向 Alpha 混合算法去除 Gemini/Nano Banana 图片水印,支持批量处理与下载。 在线工具,Gemini 图片去水印在线工具,online

    • curl 转代码

      解析常见 curl 参数并生成 fetch、axios、PHP curl 或 Python requests 示例代码。 在线工具,curl 转代码在线工具,online

    • Base64 字符串编码/解码

      将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

    • Base64 文件转换器

      将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

    • Markdown转HTML

      将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML转Markdown 互为补充。 在线工具,Markdown转HTML在线工具,online