今天给大家分享一篇朋友整理的文章,介绍了非常多的 Python 命令行式工具,这些工具绝大部分,我在 《Python黑魔法手册》中都有介绍过,感兴趣的可以去 http://magic.iswbm.com 学习。
启动一个http静态文件服务
# python -m http.server
Serving HTTP on :: port 8000 (http://[::]:8000/) ...
格式化json数据
# echo '{"amount":3.4}' | python -m json.tool
{
"amount": 3.4
}
idlelib模块基于tkinter,可以作为编辑器和shell使用。文件编辑器效果。
python -m idlelib myapp/example.py
gui-ideshell效果
python -m idlelib
gui-shell
构建myapp目录如下:
├── myapp
│ ├── example.py
│ └── hello.py
代码分别如下:
# example.py
import hello
def main():
print('Hello World')
hello.say_hello("python")
if __name__=='__main__':
main()
# hello.py
def say_hello(name):
print("hello",name)
将整个myapp打包成应用程序,命令执行后会生成一个名叫 myapp.pyz 应用程序。
python -m zipapp myapp -m "example:main"
使用python直接运行应用程序
# python myapp.pyz
Hello World
hello python
rot13(rotate by 13 places)是一种简易的替换式密码,是凯撒密码的变种。rot13将原文偏移13位形成密文,因为英文总共26位,所以密文再偏移13位后会回到原文。公式: rot13(rot13(xxx))=xxx
。
# echo "xxx" | python -m encodings.rot_13
Tvir zr n fgne
作为一个小彩蛋,欢迎大家动手破译一下xxx的值
对一个字符串进行base64编码
# echo "haha" | python -m base64
aGFoYQo=
# echo "aGFoYQo=" | python -m base64 -d
haha
base64还支持对文件编码。编写测试代码
# sample.py
def main():
print('Hello World')
if __name__=='__main__':
main()
将代码编译成base64字符串
# python -m base64 sample.py
CmRlZiBtYWluKCk6CiAgIHByaW50KCdIZWxsbyBXb3JsZPCfkYwnKQogICAKaWYgX19uYW1lX189
PSdfX21haW5fXyc6CiAgIG1haW4oKQo=
执行编译后的代码
# echo "CmRlZiBtYWluKCk6CiAgIHByaW50KCdIZWxsbyBXb3JsZPCfkYwnKQogICAKaWYgX19uYW1lX189
PSdfX21haW5fXyc6CiAgIG1haW4oKQo=" | python -m base64 -d | python
Hello World
类似的可以使用uu(Unix-to-Unix encoding)编码代码:
# python -m uu sample.py
begin 644 sample.py
M"F1E9B!M86EN*"DZ"B @('!R:6YT*"=(96QL;R!7;W)L9/"?D8PG*0H@(" *
C:68@7U]N86UE7U\]/2=?7VUA:6Y?7R<Z"B @(&UA:6XH*0H
end
使用quopri(Encode and decode MIME quoted-printable data)编码代码:
# python -m quopri -t sample.py
def=20main():
=20=20=20print('Hello=20World=F0=9F=91=8C')
=20=20=20
if=20__name__=3D=3D'__main__':
=20=20=20main()
识别文件或者url的mime类型
# python -m mimetypes https://docs.python.org/3/library/mimetypes.html
type: text/html encoding: None # html
# python -m mimetypes https://www.google.com/images/branding/googlelogo/2x/googlelogo_color_272x92dp.png
type: image/png encoding: None # png
# python -m mimetypes sample.py
type: text/x-python encoding: None # python文件
# python -m mimetypes sample.py.gz
type: text/x-python encoding: gzip # python文件,gzip压缩
python -m sysconfig
Platform: "macosx-10.9-x86_64"
Python version: "3.8"
Current installation scheme: "posix_prefix"
Paths:
data = "/Users/yoo/work/yuanmahui/python/.venv"
include = "/Library/Frameworks/Python.framework/Versions/3.8/include/python3.8"
...
Variables:
...
PYTHON = "python"
PYTHONFRAMEWORK = "Python"
PYTHONFRAMEWORKDIR = "Python.framework"
PYTHONFRAMEWORKINSTALLDIR = "/Library/Frameworks/Python.framework"
...
也可以使用下面命令查看系统路径
# python -m site
sys.path = [
'/Users/yoo/work/yuanmahui/python/python-tools',
'/Library/Frameworks/Python.framework/Versions/3.8/lib/python38.zip',
'/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8',
'/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/lib-dynload',
'/Users/yoo/work/yuanmahui/python/.venv/lib/python3.8/site-packages',
]
USER_BASE: '/Users/yoo/Library/Python/3.8' (exists)
USER_SITE: '/Users/yoo/Library/Python/3.8/lib/python/site-packages' (exists)
ENABLE_USER_SITE: False
compileall可以编译python脚本。myapp目录有2个py脚本
# ll myapp
total 16
-rw-r--r-- 1 yoo staff 118B 2 26 23:03 example.py
-rw-r--r-- 1 yoo staff 43B 2 26 23:03 hello.py
编译脚本
# python -m compileall myapp
Listing 'myapp'...
Compiling 'myapp/example.py'...
Compiling 'myapp/hello.py'...
查看编译结果
tree myapp -L 3
myapp
├── __pycache__
│ ├── example.cpython-38.pyc
│ └── hello.cpython-38.pyc
├── example.py
└── hello.py
1 directory, 4 files
创建和解压tar包
# python -m tarfile -c myapp.tar myapp # 创建myapp.tar 压缩包
# python -m tarfile -e myapp.tar myapp2 # 解压myapp.tar 到 myapp2目录
使用gzip压缩文件
# python -m gizp sample.py
# python -m gzip -d sample.py.gz
使用zip打包文件
# python -m zipfile -c myapp.zip myapp
# python -m zipfile -e myapp.zip myapp2
注意: zipfile和zipapp不一样, 后则是生成一个可以执行的app
没有telnet工具的python容器中可以这样:
# python -m telnetlib -d redis 6379 # 连接redis
monitor
Telnet(redis,6379): send b'monitor\n'
Telnet(redis,6379): recv b'-NOAUTH Authentication required.\r\n'
-NOAUTH Authentication required.
还有 nntplib && ftplib 两个工具,应该很少使用,就不介绍了
自带的timeit可以测试脚本的性能数据
# python -m timeit '"-".join([str(n) for n in range(100) if n%2 == 0])' # 取模求偶数
20000 loops, best of 5: 12.5 usec per loop
# python -m timeit '"-".join([str(n) for n in range(0,100,2)])' # 步进
50000 loops, best of 5: 8.85 usec per loop
# python -m timeit '"-".join([str(n) for n in range(100) if n&1 == 0])' # 位运算判断奇偶
20000 loops, best of 5: 14.3 usec per loop
不科学1: 位运算竟然比取模慢?
如果不是一个字符串而是一个脚本:
def test_normal():
tmp = ""
for x in range(100):
if x % 2 == 0:
if tmp:
tmp = tmp+"-"+str(x)
else:
tmp = str(x)
return tmp
if __name__ == '__main__':
print(test_normal())
可以下面方式变通使用
# python -m base64 test_string_join.py | python -m base64 -d | python -m timeit
50000000 loops, best of 5: 5.33 nsec per loop
不科学2: 50000000循环只需要5.33纳秒,而之前的用例20000循环需要12.5微秒
标准库中还有 pdb && profile && pstats 使用比较复杂,暂时就不介绍
pypy3 -m timeit '[{} for n in range(1000)]'
WARNING: timeit is a very unreliable tool. use pyperf or something else for real measurements
pypy3 -m pip install pyperf
pypy3 -m pyperf timeit '[{} for n in range(1000)]'
------------------------------------------------------------
100000 loops, average of 7: 7.3 +- 0.107 usec per loop (using standard deviation)
[tywork@liujunhong_szfsfz_work1 config]$ pypy3 -m pyperf timeit '[{} for n in range(1000)]'
........
Mean +- std dev: 8.42 us +- 0.25 us
[tywork@liujunhong_szfsfz_work1 config]$
[tywork@liujunhong_szfsfz_work1 config]$
[tywork@liujunhong_szfsfz_work1 config]$
[tywork@liujunhong_szfsfz_work1 config]$ pypy3 -m pyperf timeit '[dict() for n in range(1000)]'
.........
Mean +- std dev: 29.6 us +- 1.1 us
本地服务方式查看python代码文档
# python -m pydoc -p 8080 # 启动一个web服务
Server ready at http://localhost:8080/
Server commands: [b]rowser, [q]uit
server> b
文档效果如图
执行python自带的测试用例,查看系统支持那些特性
# python -m test.regrtest -u cpu
== CPython 2.7.16 (default, Jun 5 2020, 22:59:21) [GCC 4.2.1 Compatible Apple LLVM 11.0.3 (clang-1103.0.29.20) (-macos10.15-objc-
== Darwin-19.6.0-x86_64-i386-64bit little-endian
== /private/var/folders/mv/3vgd3mdx2453clfcst7qlm280000gn/T/test_python_13470
== CPU count: 12
Run tests sequentially
0:00:00 load avg: 2.53 [ 1/404] test_grammar
...
= Tests result: FAILURE ==
363 tests OK.
5 tests failed:
test_import test_posix test_py_compile test_rlcompleter
test_scriptpackages
36 tests skipped:
test_al test_bsddb test_bsddb3 test_cd test_cl test_codecmaps_cn
test_codecmaps_hk test_codecmaps_jp test_codecmaps_kr
test_codecmaps_tw test_curses test_epoll test_gdb test_gdbm
test_gl test_imgfile test_largefile test_linuxaudiodev test_msilib
test_ossaudiodev test_poll test_py3kwarn test_smtpnet
test_socketserver test_spwd test_startfile test_sunaudiodev
test_timeout test_tk test_tools test_ttk_guionly test_urllib2net
test_urllibnet test_winreg test_winsound test_zipfile64
2 skips unexpected on darwin:
test_spwd test_tools
Total duration: 5 min 23 sec
Tests result: FAILURE
从测试用例,可以看到osx支持fork,不支持epoll和poll。
0:00:47 load avg: 1.79 [138/404] test_fork1
...
0:00:39 load avg: 1.59 [125/404] test_epoll
test_epoll skipped -- test works only on Linux 2.6
...
0:02:42 load avg: 2.41 [257/404/1] test_poll
test_poll skipped -- select.poll not defined -- skipping test_poll
0:02:42 load avg: 2.41 [258/404/1] test_popen -- test_poll skipped
本文由哈喽比特于3年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/YdK-cWqQCcJDyRpGKEw-SA
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。