当前位置:首页 » 编程语言 » python的webbrowser

python的webbrowser

发布时间: 2023-05-28 07:19:03

python webbrowser

这明卖个跟浏览器的API接口有关 ,和python没什么关系的侍掘

webbrowser.open() 方法是激谈逗直接调用系统默认的浏览器而已

② Linux 下Python 脚本编写的"奇技淫巧"

“ 生命完美的答案,无非走过没有遗憾 ---《天蓝》”

“如何能够解析脚本运行命令行选项(位于 sys.argv 中)”

argparse 模块可被用来解析命令行选项

常用来定义一个脚本的说明文档,一般我们写python脚本会通过 if..else 的方式来提供一个脚本说明文档,python不支持switch。所以很麻烦,其实,我们可以通过 argparse 来编写说明文档。

我们来看看怎么执行一个python脚本

对于熟悉Linux的小伙伴下面的文档在熟悉不过了,这个一个标准Linxu软件包的说明文档,文档中定义是软件包的说明

来看看这个脚本是如何编写的

为了解析命令行选项, 首先要创建一个 ArgumentParser 实例, 使用 add_argument() 方法声明你想要支持的选项。在每个 add-argument() 调用中:

dest 参数指定解析结果被指派给属性的名字。 metavar 参数被用来生成帮助信息。

action 参数 指定跟属性对应的处理逻辑,通常的 值为 store , 被用来存储 某个值 或将 多个参数值收集到一个列表中 。

nargs 参数收集 所有剩余的命令行参数到一个列表中。在本例中它被用来构造一个文件名列表

action='store_true' 根据参数是否存在来设置一个位置 Boolean 标志:

action='store' 参数接受一个单独值并将其存储为一个字符串

如果一个都没有,会提示缺少参数 -p/--pat

choices={'slow', 'fast'}, 参数说明接受一个值,但是会将其和可能的选择值做比较,以检测其合法性:

一旦参数选项被指定,你就可以执行 parser.parse() 方法了。它会处理 sys.argv 的值并返回一个结果实例。每个参数值会被设置成该实例中 add_argument() 方法的 dest 参数指定的属性值。

还很多种其他方法解析命令行选项。可以会手动地处理 sys.argv 或者使用 getopt 模块 。但是,如果你采用本节的方式,将会减少很多冗余代码,底层细节 argparse 模块 已经帮你处理好了。你可能还会碰到使用 optparse 库解析选项的代码。尽管 optparse 和 argparse 很像 ,但是后者更先进,因此在新的程序中你应该使用它。

“你写了个脚本,运行时需要一个密码。此脚本是交互式的,因此不能将密码在脚本中硬编码,而是需要弹出一个密码输入提示,让用户自己输入。”

Python 的 getpass 模块 正是你所需要的。你可以让你很轻松地弹出密码输入提示,并且不会在用户终端显示密码。

代码中 getpass.getuser() 不会弹出用户名的输入提示。它会根据该 用户的 shell 环境 或者会依据 本地系统的密码库 (支持 pwd 模块的平台)来使用 当前用户的登录名

在bash中编写pytohn脚本接收外部数据的方式,一般情况下,对于一般变量,我们用命令行变量的方式比较多(手动的处理 sys.argv ),对于 文件内容或者bash命令输出 直接通过脚本内部获取需要的数据。

其实python 脚本也可以用其他方式来接收 传递给他的 文件数据或者bash命令输出 ,包括将 命令行的输出 通过 管道传递 给该脚本、 重定向文件到该脚本 ,或在 命令行中传递一个文件名 或 文件名列表 给该脚本。

这里通过 Python 内置的 fileinput 模块 ,可以实现重 定向,管道,以文佳输出 的方式传递数据到脚本内部

使用 fileinput.input() 方法可以获取当前输入脚本的数据,脚本里面用一个 FileInput 迭代器接收

文件直接接收

重定向接收

管道方式接收

fileinput.input() 创建并返回一个 FileInput 类的实例,该实例可以被当做一个 上下文管理器 使用。因此,整合起来,如果我们要写一个打印多个文件输出的脚本,那么我们需要在输出中包含文件名和行号

“你想执行一个外部命令并以 Python 字符串的形式获取执行结果。”

使用 subprocess.check_output() 函数。

执行下试试

如果被执行的命令以非零码返回,就会抛出异常。下面的例子捕获到错误并获取返回码:

默认情况下, check_output() 仅仅返回输入到标准输出的值。如果你需要 同时收集标准输出和错误输出 ,使用 stderr 参数:

如果你需要用一个超时机制来执行命令,使用 timeout 参数:

通常来讲,命令的执行 不需要 使用到 底层 shell 环境(比如 sh、bash) 。一个字符串行表会被传递给一个 低级系统命令 ,比如 os.execve() 。

如果你想让 命令被一个shell 执行 ,传递一个字符串参数,并设置参数 shell=True . 有时候你想要 Python 去执行一个复杂的 shell 命令 的时候这个就很有用了,比如管道流、I/O 重定向和其他特性。例如:

是在 shell 中执行命令会存在一定的安全风险,特别是当参数来自于用户输入时。这时候可以使用 shlex.quote() 函数 来将参数正确的用双引用引起来。

使用 check_output() 函数 是执行 外部命令 并获取其 返回值 的最简单方式。但是,如果你需要对 子进程做更复杂的交互 ,比如给它发送输入,你得采用另外一种方法。这时候可直接使用 subprocess.Popen 类。

关于子进程,简单来看下

也可以进程列表同协程结合的方式。你既可以在子shell中 进行繁重的处理工作,同时也不会让子shell的I/O受制于终端。

如果直接丢到后台会自动在终端输出IO

subprocess 模块对于依赖 TTY 的外部命令不合适用 。例如,你不能使用它来自动化一个用户输入密码的任务(比如一个 ssh 会话)。这时候,你需要使用到第三方模块了,比如基于着名的 expect 家族的工具(pexpect 或类似的)(pexpect可以理解为Linux下的expect的Python封装、通过pexpect可以实现对ssh、ftp、passwd、telnet等命令行进行自动交互,而无需人工干涉来达到自动化的目的。比如我们可以模拟一个FTP登录时所有交互,包括输入主机地址、用户名、密码、上传文件等,待出现异常还可以进行尝试自动处理。)

“你想向标准错误打印一条消息并返回某个非零状态码来终止程序运行”

通过 python 的 raise SystemExit(3) 命令可以主动抛出一个错误,通过 sys.stderr.write 将命令写到标准的输出端

直接将消息作为参数传给 SystemExit() ,那么你可以省略其他步骤

抛出一个 SystemExit 异常,使用错误消息作为参数,它会将消息在 sys.stderr 中打印,然后程序以状态码 1 退出

“你需要知道当前终端的大小以便正确的格式化输出。”

使用 os.get terminal size() 函数 来做到这一点。

“复制或移动文件和目录,但是又不想调用 shell 命令。”

shutil 模块 有很多便捷的函数可以复制文件和目录。使用起来非常简单

这里不多讲,熟悉Linux的小伙伴应该不陌生。

默认情况下,对于 符号链接 这些命令处理的是它指向的东西文件。例如,如果 源文件 是一个 符号链接 ,那么目标文件将会是 符号链接 指向的文件。如果你只想 复制符号链接本身 ,那么需要指定 关键字 参数 follow_symlinks

tree() 可以让你在复制过程中选择性的忽略某些文件或目录。你可以提供一个忽略函数,接受一个目录名和文件名列表作为输入,返回一个忽略的名称列表。例如:

对于文件元数据信息, 2() 这样的函数只能尽自己最大能力来保留它。 访问时间、创建时间和权限 这些基本信息会被保留,但是 对于所有者、ACLs、资源 fork 和其他更深层次的文件元信息就说不准了

通常不会去使用 shutil.tree() 函数 来执行 系统备份 。当处理文件名的时候,最好使用 os.path 中的函数来确保最大的可移植性

使用 tree() 复制文件夹的一个棘手的问题是对于错误的处理,可以使用异常块处理,或者通过 参数 ignore dangling symlinks=True 忽略掉无效符号链接。

“创建或解压常见格式的归档文件(比如.tar, .tgz 或.zip)”

shutil 模块拥有两个函数—— make archive() 和 unpack archive() 可派上用场,

make archive() 的第二个参数是期望的输出格式。可以使用 get archive formats() 获取所有支持的归档格式列表。

“你需要写一个涉及到文件查找操作的脚本,比如对日志归档文件的重命名工具,你不想在 Python 脚本中调用 shell,或者你要实现一些 shell 不能做的功能。”

查找文件,可使用 os.walk() 函数 ,传一个顶级目录名给它

os.walk() 方法 为我们 遍历目录树 ,每次进入一个目录,它会返回一个 三元组 ,包含 相对于查找目录的相对路径,一个该目录下的目录名列表,以及那个目录下面的文件名列表。

对于每个元组,只需检测一下目标文件名是否在文件列表中。如果是就使用 os.path.join() 合并路径。为了避免奇怪的路径名比如 ././foo//bar ,使用了另外两个函数来修正结果

os.walk(start) 还有跨平台的优势。并且,还能很轻松的加入其他的功能。我们再演示一个例子,下面的函数打印所有最近被修改过的文件:

打印10分钟之前被修改的数据

“怎样读取普通.ini 格式的配置文件?”

configparser 模块 能被用来读取配置文件

编写配置文件

如果有需要,你还能修改配置并使用 cfg.write() 方法将其写回到文件中

“你希望在脚本和程序中将诊断信息写入日志文件。”

python 脚本打印日志最简单方式是使用 logging 模块

五个日志调用( critical(), error(), warning(), info(), debug() )以降序方式表示不同的严重级别。 basicConfig() 的 level 参数是一个 过滤器 。所有级别低于此级别的日志消息都会被忽略掉。每个 logging 操作的参数是一个消息字符串,后面再跟一个或多个参数。构造最终的日志消息的时候我们使用了 % 操作符来格式化消息字符串。

如果你想使用配置文件,可以像下面这样修改 basicConfig() 调用:

logconfig.ini

在调用日志操作前先执行下 basicConfig() 函数方法 ,可以找标准输出或者文件中输出

basicConfig() 在程序中只能被执行一次。如果你稍后想改变日志配置,就需要先获取 root logger ,然后直接修改它。

更多见日志模块文档https://docs.python.org/3/howto/logging-cookbook.html

“你想给某个函数库增加日志功能,但是又不能影响到那些不使用日志功能的程序。”

对于想要执行日志操作的函数库,你应该创建一个专属的 logger 对象,并且像下面这样初始化配置:

使用这个配置,默认情况下不会打印日志,只有配置过日志系统,那么日志消息打印就开始生效

通常来讲,不应该在函数库代码中 自己配置日志系统 ,或者是已经有个已经存在的日志配置了。调用 getLogger( name ) 创建一个和调用模块同名的 logger 模块 。由于 模块 都是唯一的,因此创建的 logger 也将是唯一 的。所以当前进程中只有一个logging会生效。

log.addHandler(logging.NullHandler()) 操作将一个 空处理器 绑定到刚刚已经创建好的 logger 对象 上。一个空处理器默认会忽略调用所有的日志消息。因此,如果使用该函数库的时候还没有配置日志,那么将不会有消息或警告出现。

在这里,根日志被配置成仅仅 输出 ERROR 或更高级别的消息 。不过, somelib 的日志级别被单独配置成可以输出 debug 级别的消息, 它的优先级比全局配置高。像这样更改单独模块的日志配置对于调试来讲是很方便的,因为你无需去更改任何的全局日志配置——只需要修改你想要更多输出的模块的日志等级。(这个还有待研究)

“你想记录程序执行多个任务所花费的时间”

time 模块 包含很多函数来执行跟时间有关的函数。尽管如此,通常我们会在此基础之上构造一个更高级的接口来模拟一个计时器。

这个类定义了一个可以被用户根据需要启动、停止和重置的计时器。它会在elapsed 属性中记录整个消耗时间。下面是一个例子来演示怎样使用它:

这里通过 __enter__,__exit__ ,使用 with 语句 以及上下文管理器协议可以省略计时器打开和关闭操作。(关于上下文管理协议,即with语句,为了让一个对象兼容with语句,必须在这个对象的类中声明 __enter__和__exit__方法, , __enter__ 在出现with语句被调用, __exit__ 在代码执行完毕被调用,可以参考open()方法)

在计时中要考虑一个 底层的时间函数问题 。 一般来说, 使用 time.time() 或 time.clock() 计算的时间精度因操作系统的不同会有所不同。而使用 time.perf_counter() 函数可以确保使用系统上面 最精确的计时器 。

“你想对在 Unix 系统上面运行的程序设置内存或 CPU 的使用限制。”

resource 模块 能同时执行这两个任务。例如,要限制 CPU 时间,下面的代码在windows平台执行不了,但是Linux是可以的。

程序运行时, SIGXCPU 信号 在时间过期时被生成,然后执行清理并退出。

这暂时没有好的Demo...

程序运行到没有多余内存时会抛出 MemoryError 异常。

setrlimit() 函数 被用来设置特定资源上面的 软限制和硬限制 。

setrlimit() 函数 还能被用来设置 子进程数量、打开文件数以及类似系统资源的限制(cgroup) 。

“通过脚本启动浏览器并打开指定的 URL 网页”

webbrowser 模块 能被用来启动一个浏览器,并且与平台无关

新窗口打卡网站

当前窗口打开一个tab页

指定浏览器类型,可以使用 webbrowser.get() 函数

③ 如何使用python 中webbrowser.register 注册一个浏览器

python的webbrowser模块支持对浏缓昌览器进行一些蠢哪汪操作,主要有以下三个方法:带仔 import webbrowser webbrowser.open(url, new=0, autoraise=True) webbrowser.open_new(url) webbrowser.open_new_tab(url)

④ 如何使用python进行浏览器行为模拟

你可以使用python的webbrowser库来模拟浏览器: url = '' # Open URL in a new tab, if a browser window is already open.webbrowser.open_new_tab(url + 'doc/') # Open URL in new window, raising the window if possible.webbrowser.open_new(url)或者使用python的第三方库, selenium from selenium import webdriverfrom selenium.webdriver.common.keys import Keys browser = webdriver.Firefox() browser.get(')assert 'Yahoo!' in browser.title elem = browser.find_element_by_name('p') # Find the search boxelem.send_keys('seleniumhq' + Keys.RETURN) browser.quit()

⑤ 怎样实现在一个浏览器中同时登入两个帐号

怎样实现在一个浏览器中同时登入两个帐号

360浏览器点选右上角档案-新建无痕/小号视窗,快捷键是Ctrl+shirt+N
在小号视窗登陆另一账号即可,则不同页面有不同账号

webqq 能在隐坦侍一个浏览器上同时登入两个或以上qq帐号吗

是的,这是可以的。互不干扰。望采纳,打字不容易

现在一个12306帐号不能在多个浏览器同时登陆吗

现在一个12306帐号在同一个电脑的一个浏览器登入后。
如果换一个浏览器保留原浏览器页面开启的情况下。
第一个浏览器帐号就会提示退出,而登入第二个浏览器。
也就是说12306帐号在同一电脑不能多个浏览器同时登入。

用Chrome 浏览器怎样同时登入多个新浪帐号

简单,在设定里有个使用者,新增新使用者,在不同使用者里就能好几个一起登了

第1种方法,是使用chrome微博外挂:FaWave,
第2种方法,是在同一台电脑上,建立多个chrome快捷方式,并设定不同的启动引数,具体步骤:
:jingyan../article/624e7459b685f034e8ba5a9d.

怎么python程式码在一个浏览器中同时开启两个tab页面

python的webbrowser模组支援对浏览器进行一些操作,主要有以下三个方法:
import webbrowser
webbrowser.open(url, new=0, autoraise=True)
webbrowser.open_new(url)
webbrowser.open_new_tab(url)

怎样把-个浏览信滑器的帐号汇入另一个浏览器中

除非两个浏览器支援用同一个账号同步你的收藏,账号密码。或者可以共用一个账号管理外挂。

360浏览器在电脑上能同时登入两个不同12306帐号抢票吗

你说的方法是不可以的,你可以用两个浏览器登入两个帐号是可以的哟亲!

在同一个浏览哭器中能同时登入两个126邮箱,现在不知怎么了,不能同时登入,

在桌面点浏览器登陆126邮箱之后灶吵最小化,在点浏览器再次点126邮箱登陆,就可以

⑥ python webbrowser.open("http://baidu.com") 只能打开空白页面

importwebbrowser

webbrowser.open("www..com"仿袭)

pyCharm+python3.6,可以备芹兄正常打开首氏指定url

⑦ 用webbrowser操作浏览器登录微博后,怎么抓取数据,Python语言

按我的理解简化如下:
用户在新浪微博给的页面输入账号密码,然后微博给应用一个PIN码,这样应用通过PIN码才有权限访问该用户的信息,而应用在整个过程中是接触不到密码的,所以用户觉得很安全,后果很满意
2:获得认证之后,就可以使用微博SDK提供的API获得信息啦
3:如果想设计web或者客户端应用的话,那就继续加个GUI好啦(未完成)

代码:

#!/usr/bin/python

import webbrowser

from weibopy.auth import OAuthHandler
from weibopy.api import API

AppKey = '2525355147'
AppSecret = ''

my_auth = OAuthHandler(AppKey , AppSecret)
webbrowser.open(my_auth.get_authorization_url())
verifier = raw_input('PIN: ').strip()
my_auth.get_access_token(verifier)

my_api = API(my_auth)
for comment in my_api.mentions():
object = comment
id = object.__getattribute__("id")
text = object.__getattribute__("text")
print str(id) + " : " + text

⑧ 如何使用python 中webbrowser.register 注册一个浏览器

基于IE内核的浏览器直接用VB编写即可。引用WEBbrowser就可以了。复杂的操作可能要实现某些接口,拍袭比迹贺碧如拦截下载事件等。这部分用VB比较复姿举杂,用Delphi比较合适。

webkit有现成封装的ActiveX,可以直接被VB调用。
但自己编写webkit内核的浏览器比较困难。

⑨ 在python中一共有多少个标准库

Python 语言官方的参考手册钟,介绍了与 Python 一同发行的标准库。

文本处理服务

  • string--- 常见的字符串操作

  • re--- 正则表达式操作

  • difflib--- 计算差异的辅助工具

  • textwrap--- 文本自动换行与填充

  • unicodedata--- Unicode 数据库

  • stringprep--- 因特网字符串预备

  • readline--- GNU readline 接口

  • rlcompleter--- GNU readline 的补全函数

二进制数据服务

  • struct--- 将字节串解读为打包的二进制数据

  • codecs--- 编解码器注册和相关基类

数据类型

  • datetime--- 基本日期和时间类型

  • zoneinfo--- IANA 时区支持

  • calendar--- 日历相关函数

  • collections--- 容器数据类型

  • collections.abc--- 容器的抽象基类

  • heapq--- 堆队列算法

  • bisect--- 数组二分查找算法

  • array--- 高效的数值数组

  • weakref--- 弱引用

  • types--- 动态类型创建和内置类型名称

  • --- 浅层 (shallow) 和深层 (deep) 复制操作

  • pprint--- 数据美化输出

  • reprlib--- 另一种repr()实现

  • enum--- 对枚举的支持

  • graphlib--- 操作类似图的结构的功能

数字和数学模块

  • numbers--- 数字的抽象基类

  • math--- 数学函数

  • cmath--- 关于复数的数学函数

  • decimal--- 十进制定点和浮点运算

  • fractions--- 分数

  • random--- 生成伪随机数

  • statistics--- 数学统计函数

函数式编程模块

  • itertools--- 为高效循环而创建迭代器的函数

  • functools--- 高阶函数和可调用对象上的操作

  • operator--- 标准运算符替代函数

文件和目录访问

  • pathlib--- 面向对象的文件系统路径

  • os.path--- 常用路径操作

  • fileinput--- 迭代来自多个输入流的行

  • stat--- 解析stat()结果

  • filecmp--- 文件及目录的比较

  • tempfile--- 生成临时文件和目录

  • glob--- Unix 风格路径名模式扩展

  • fnmatch--- Unix 文件名模式匹配

  • linecache--- 随机读写文本行

  • shutil--- 高阶文件操作

数据持久化

  • pickle--- Python 对象序列化

  • reg--- 注册配合pickle模块使用的函数

  • shelve--- Python 对象持久化

  • marshal--- 内部 Python 对象序列化

  • dbm--- Unix "数据库" 接口

  • sqlite3--- SQLite 数据库 DB-API 2.0 接口模块

数据压缩和存档

  • zlib--- 与gzip兼容的压缩

  • gzip--- 对gzip格式的支持

  • bz2--- 对bzip2压缩算法的支持

  • lzma--- 用 LZMA 算法压缩

  • zipfile--- 使用ZIP存档

  • tarfile--- 读写tar归档文件

文件格式

  • csv--- CSV 文件读写

  • configparser--- 配置文件解析器

  • tomllib--- Parse TOML files

  • netrc--- netrc 文件处理

  • plistlib--- 生成与解析 Apple.plist文件

加密服务

  • hashlib--- 安全哈希与消息摘要

  • hmac--- 基于密钥的消息验证

  • secrets--- 生成管理密码的安全随机数

通用操作系统服务

  • os--- 多种操作系统接口

  • io--- 处理流的核心工具

  • time--- 时间的访问和转换

  • argparse--- 命令行选项、参数和子命令解析器

  • getopt--- C 风格的命令行选项解析器

  • logging--- Python 的日志记录工具

  • logging.config--- 日志记录配置

  • logging.handlers--- 日志处理程序

  • getpass--- 便携式密码输入工具

  • curses--- 终端字符单元显示的处理

  • curses.textpad--- 用于 curses 程序的文本输入控件

  • curses.ascii--- 用于 ASCII 字符的工具

  • curses.panel--- curses 的面板栈扩展

  • platform--- 获取底层平台的标识数据

  • errno--- 标准 errno 系统符号

  • ctypes--- Python 的外部函数库

并发执行

  • threading--- 基于线程的并行

  • multiprocessing--- 基于进程的并行

  • multiprocessing.shared_memory--- Shared memory for direct access across processes

  • concurrent包

  • concurrent.futures--- 启动并行任务

  • subprocess--- 子进程管理

  • sched--- 事件调度器

  • queue--- 一个同步的队列类

  • contextvars--- 上下文变量

  • _thread--- 底层多线程 API

网络和进程间通信

  • asyncio--- 异步 I/O

  • socket--- 底层网络接口

  • ssl--- 套接字对象的 TLS/SSL 包装器

  • select--- 等待 I/O 完成

  • selectors--- 高级 I/O 复用库

  • signal--- 设置异步事件处理程序

  • mmap--- 内存映射文件支持

互联网数据处理

  • email--- 电子邮件与 MIME 处理包

  • json--- JSON 编码和解码器

  • mailbox--- 操作多种格式的邮箱

  • mimetypes--- 映射文件名到 MIME 类型

  • base64--- Base16, Base32, Base64, Base85 数据编码

  • binascii--- 二进制和 ASCII 码互转

  • quopri--- 编码与解码经过 MIME 转码的可打印数据

结构化标记处理工具

  • html--- 超文本标记语言支持

  • html.parser--- 简单的 HTML 和 XHTML 解析器

  • html.entities--- HTML 一般实体的定义

XML处理模块

  • xml.etree.ElementTree--- ElementTree XML API

  • xml.dom--- 文档对象模型 API

  • xml.dom.minidom--- 最小化的 DOM 实现

  • xml.dom.pulldom--- 支持构建部分 DOM 树

  • xml.sax--- 支持 SAX2 解析器

  • xml.sax.handler--- SAX 处理句柄的基类

  • xml.sax.saxutils--- SAX 工具集

  • xml.sax.xmlreader--- 用于 XML 解析器的接口

  • xml.parsers.expat--- 使用 Expat 的快速 XML 解析

互联网协议和支持

  • webbrowser--- 方便的 Web 浏览器控制工具

  • wsgiref--- WSGI 工具和参考实现

  • urllib--- URL 处理模块

  • urllib.request--- 用于打开 URL 的可扩展库

  • urllib.response--- urllib 使用的 Response 类

  • urllib.parse用于解析 URL

  • urllib.error--- urllib.request 引发的异常类

  • urllib.robotparser--- robots.txt 语法分析程序

  • http--- HTTP 模块

  • http.client--- HTTP 协议客户端

  • ftplib--- FTP 协议客户端

  • poplib--- POP3 协议客户端

  • imaplib--- IMAP4 协议客户端

  • smtplib--- SMTP 协议客户端

  • uuid---RFC 4122定义的UUID对象

  • socketserver--- 用于网络服务器的框架

  • http.server--- HTTP 服务器

  • http.cookies--- HTTP状态管理

  • http.cookiejar—— HTTP 客户端的 Cookie 处理

  • xmlrpc--- XMLRPC 服务端与客户端模块

  • xmlrpc.client--- XML-RPC 客户端访问

  • xmlrpc.server--- 基本 XML-RPC 服务器

  • ipaddress--- IPv4/IPv6 操作库

多媒体服务

  • wave--- 读写WAV格式文件

  • colorsys--- 颜色系统间的转换

国际化

  • gettext--- 多语种国际化服务

  • locale--- 国际化服务

程序框架

  • turtle--- 海龟绘图

  • cmd--- 支持面向行的命令解释器

  • shlex—— 简单的词法分析

  • Tk图形用户界面(GUI)

  • tkinter—— Tcl/Tk 的 Python 接口

  • tkinter.colorchooser--- 颜色选择对话框

  • tkinter.font--- Tkinter 字体封装

  • Tkinter 对话框

  • tkinter.messagebox--- Tkinter 消息提示

  • tkinter.scrolledtext--- 滚动文字控件

  • tkinter.dnd--- 拖放操作支持

  • tkinter.ttk--- Tk 风格的控件

  • tkinter.tix--- TK扩展包

⑩ python里webbrowser怎么关闭游览器

fromselenium稿段import洞轿webdriver
browser=纳敬肆webdriver.Firefox()
browser.quit()

热点内容
内置存储卡可以拆吗 发布:2025-05-18 04:16:35 浏览:336
编译原理课时设置 发布:2025-05-18 04:13:28 浏览:378
linux中进入ip地址服务器 发布:2025-05-18 04:11:21 浏览:612
java用什么软件写 发布:2025-05-18 03:56:19 浏览:32
linux配置vim编译c 发布:2025-05-18 03:55:07 浏览:107
砸百鬼脚本 发布:2025-05-18 03:53:34 浏览:944
安卓手机如何拍视频和苹果一样 发布:2025-05-18 03:40:47 浏览:742
为什么安卓手机连不上苹果7热点 发布:2025-05-18 03:40:13 浏览:803
网卡访问 发布:2025-05-18 03:35:04 浏览:511
接收和发送服务器地址 发布:2025-05-18 03:33:48 浏览:372