DevWeekly/docs/8-pyhubweekly.md

7.9 KiB
Raw Permalink Blame History

前言

PyHubWeekly每周定期更新精选GitHub上优质的Python项目/小工具。

如果喜欢,麻烦给个Star支持一下吧。此外,欢迎大家通过提交issue来投稿和推荐自己的项目~

本期为大家推荐GitHub上5个优质的Python项目它们分别是

  • newscatcher
  • pycodestyle
  • pywinauto
  • real-url
  • docopt

下面分别来介绍一下上述5个GitHub项目。

newscatcher

Star719

newscatcher获取新闻资讯的工具包它时刻监控者成千上万个新闻媒体并对其进行聚合它包含丰富的API接口开发者可以通过时间新闻源关键字等方式来获取新闻资讯。

也许会有同学疑惑,我们已经有这么多新闻软件,这个工具有什么价值呢?

第一:对于我们常用的新闻软件,具体怎么样,我想应该都很清楚,质量参差不齐,而且广告繁多。所以,首先,我们可以通过newscatcher这个工具包获取我们想要的新闻资讯。

第二:它提供了丰富的数据源,假如你喜欢做金融数据分析,仅凭股票等这些量化的数据是很难得到很理想的分析结果,它往往受到政策和事件的影响,所以,这时候就需要一些非结构化的数据区辅助分析。而新闻,在其中就是一种非常有价值的非结构化数据。

安装:

pip install newscatcher

使用:

from newscatcher import Newscatcher
from newscatcher import get_news
from newscatcher import get_headlines


news_source = Newscatcher('blackfaldslife.com')
news = get_news('wired.co.uk')
headlines = get_headlines('wired.co.uk')

pycodestyle

Star4k

pycodestyle是根据PEP 8中的样式约定检查Python代码的工具它具有如下特性

  • 添加新代码检查很容易
  • 快速跳转到错误位置
  • 轻量化
  • 带有全面的测试套件

安装:

pip install pycodestyle
pip install --upgrade pycodestyle
pip uninstall pycodestyle

使用:

可以直接在命令行调用pycodestyle通过各种选项可以实现不同的功能例如统计错数数量、显示PEP8相关提示下面看一个示例

# E40.py
import os, sys

然后对其进行代码检查,

E40.py:1:10: E401 multiple imports on one line
import os, sys
         ^
    Place imports on separate lines.

    Okay: import os\nimport sys
    E401: import sys, os

    Okay: from subprocess import Popen, PIPE
    Okay: from myclas import MyClass
    Okay: from foo.bar.yourclass import YourClass
    Okay: import myclass
    Okay: import foo.bar.yourclass

pywinauto

Star2k

在上一期我介绍了一款网页自动化工具helium,它能够实现网页端的很多重复性工作,的确大大提高了工作效率。

如果你的工作、学习内容不仅限于网页端、如果helium还不能满足你高效工作的需求。那么pywinauto一定可以做到。

pywinauto是一款实现Windows GUI自动化的Python工具它可以将鼠标和键盘操作发送到Windows对话框和控件。此外它还支持更复杂的操作例如获取文本数据。

安装:

pip install -U pywinauto

使用:

先写一段演示代码,

from pywinauto.application import Application
app = Application().start("notepad.exe")

app.UntitledNotepad.menu_select("帮助->关于记事本")

app.UntitledNotepad.Edit.type_keys("pywinauto Works!", with_spaces = True)

img

real-url

Star256

real-url是一款解析流媒体直播源的Python工具包目前支持21个直播平台斗鱼直播、虎牙直播、哔哩哔哩直播、战旗直播、网易CC直播、火猫直播、企鹅电竞、YY直播、一直播、快手直播、花椒直播、映客直播、西瓜直播、触手直播、NOW直播、抖音直播爱奇艺直播、酷狗直播、龙珠直播、PPS奇秀直播、六间房。

获取直播源地址之后可以在PotPlayer、VLC、flv.js等播放器进行播放。

使用:

可以直接从github下载代码zip包或者克隆代码然后再命令行下执行对应的脚本即可。

不同的脚本对应不同的平台例如douyin.py对应抖音douyu.py对应斗鱼也就是说我们需要哪个平台的直播源就执行拼音对应的脚本即可。

当执行命令python [script.py]后可以输入直播房间号或者链接即可获取直播链接然后再PotPlayer打开链接即可。

下面看一下演示,

img

docopt

Star7k

docopt是一款Python风格的命令行参数解析工具它通过解析Python文件开头的注释文档来解析命令行参数格式。这样的方便之处是能够实现业务代码与命令行参数模块分开但是对注释__doc__的格式要求也比较严格。

示例,

"""
Naval Fate.

Usage:
  naval_fate ship new <name>...
  naval_fate ship <name> move <x> <y> [--speed=<kn>]
  naval_fate ship shoot <x> <y>
  naval_fate mine (set|remove) <x> <y> [--moored|--drifting]
  naval_fate -h | --help
  naval_fate --version

Options:
  -h --help     Show this screen.
  --version     Show version.
  --speed=<kn>  Speed in knots [default: 10].
  --moored      Moored (anchored) mine.
  --drifting    Drifting mine.
"""
from docopt import docopt


if __name__ == '__main__':
    arg = docopt(__doc__, argv=None, help=True, version=None, options_first=False)
    print(arg)

然后在命令行执行命令就可以看到docopt通过注释文档解析的参数

> test.py ship Guardian move 100 150 --speed=15
{'--drifting': False,
 '--help': False,
 '--moored': False,
 '--speed': '15',
 '--version': False,
 '<name>': ['Guardian'],
 '<x>': '100',
 '<y>': '150',
 'mine': False,
 'move': True,
 'new': False,
 'remove': False,
 'set': False,
 'ship': True,
 'shoot': False}

推荐阅读