官方地址:https://docs.github.com/zh/search-github/searching-on-github
本文总结了目前GitHub搜索最常用的技巧,根据我们平时搜索的内容分为了搜索存储库、搜索主题、搜索代码和搜索用户四个小点,你可以根据自己想要的搜索内容定位到每个小点,
3.1、搜索存储库
官方地址:https://docs.github.com/zh/search-github/searching-on-github/searching-for-repositories
3.1.1、按存储库名称、描述或 README 文件的内容搜索
语法 |
例子 |
in:name jquery |
匹配存储库名称中带有“jquery”的存储库。 |
in:description jquery |
匹配存储库描述中带有“jquery”的存储库。 |
in:readme jquery |
匹配存储库的 README 文件中提到“jquery”的存储库。 |
3.1.2、在用户或组织的仓库中搜索
语法 |
例子 |
user:defunkt forks:>100 |
匹配用户名为 defunkt 的具有超过 100 个 fork 的存储库。 |
org:github forks:>100 |
匹配组织名为 github 的具有超过 100 个 fork 的存储库。 |
3.1.3、按存储库大小搜索
语法 |
例子 |
size:1000 |
匹配大小为 1 MB 的存储库 |
size:>=30000 |
匹配至少 30 MB 的存储库 |
size:<50 |
匹配小于 50 KB 的存储库 |
size:50…120 |
匹配 50 KB 到 120 KB 之间的存储库 |
3.1.4、按 fork 数搜索
语法 |
例子 |
forks:5 |
匹配只有五个 fork 的存储库 |
forks:>=205 |
匹配至少有 205 个 fork 的仓库 |
forks:<90 |
匹配具有少于 90 个 fork 的存储库 |
forks:10…20 |
匹配具有 10 到 20 个 fork 的存储库 |
3.1.5、按星数搜索
语法 |
例子 |
stars:500 |
匹配恰好有 500 颗星的存储库 |
stars:10…20 |
匹配小于 1000 KB 的 10 到 20 星的存储库 |
stars:>=500 fork:true language:php |
匹配至少 500 个星的存储库,包括分叉的,用 PHP 编写的 |
3.1.6、按创建或上次更新存储库的时间搜索
语法 |
例子 |
webos created:<2011-01-01 |
匹配 2011 年之前创建的带有“webos”一词的存储库 |
css push:>2013-02-01 |
匹配 2013 年 1 月之后推送到的带有“css”一词的存储库 |
case push:>=2013-03-06 fork:only |
匹配 2013 年 3 月 6 日或之后推送到的带有单词“case”的存储库,并且是分叉。 |
3.1.7、按语言搜索
语法 |
例子 |
rails language:javascript |
匹配使用 JavaScript 编写的带有“rails”一词的存储库 |
3.1.8、按主题搜索
语法 |
例子 |
topic:jekyll |
匹配已分类为主题“jekyll”的存储库 |
3.1.9、按主题数量搜索
语法 |
例子 |
topic:5 |
匹配具有五个主题的存储库 |
topic:> 3 |
匹配具有三个以上主题的存储库 |
3.1.10、按许可证搜索
语法 |
例子 |
license:apache-2.0 |
匹配在 Apache License 2.0 下获得许可的存储库 |
3.1.11、按存储库可见性搜索
语法 |
例子 |
is:public org:github |
匹配 GitHub 拥有的公共存储库 |
is:internal test |
匹配您可以访问并包含“test”一词的内部存储库 |
is:private pages |
匹配您可以访问并包含“pages”一词的私有存储库 |
3.1.12、根据仓库是否是镜像进行搜索
语法 |
例子 |
mirror:true GNOME |
匹配作为镜像且包含单词“GNOME”的存储库 |
mirror:false GNOME |
匹配非镜像且包含“GNOME”一词的存储库 |
3.2、搜索主题
官方文档:https://docs.github.com/zh/search-github/searching-on-github/searching-topics
3.2.1、使用搜索限定符缩小搜索范围
3.3、搜索代码
官方文档:https://docs.github.com/zh/search-github/searching-on-github/searching-code
代码搜索的注意事项:由于搜索代码的复杂性,对搜索的执行方式有一些限制
- 必须登录 GitHub 上的用户帐户才能在所有公共存储库中搜索代码
- 只有当分叉的星数多于父存储库时,分叉中的代码才可搜索。星号少于父存储库的分叉不会为代码搜索编制索引。要在搜索结果中包含星数多于父级的分叉,您需要将fork:true或添加fork:only到您的查询中。有关更多信息,请参阅“在分叉中搜索”
- 仅对默认分支进行索引以进行代码搜索
- 只能搜索小于 384 KB 的文
- 只能搜索少于 500,000 个文件的存储库
- 只有在去年有活动或在搜索结果中返回的存储库才可搜索
- 除了filename搜索之外,在搜索源代码时,您必须始终包含至少一个搜索词。例如,搜索 language:javascript无效,而搜索无效amazing language:javascript
- 搜索结果最多可以显示来自同一个文件的两个片段,但文件中可能会有更多的结果
- 您不能在搜索查询中使用以下通配符:
. , : ; / \ ` ’ " = \* ! ? # $ & + ^
3.3.1、按文件内容或文件路径搜索
语法 |
例子 |
octocat in:file |
匹配文件内容中出现“octocat”的代码 |
octocat in:path |
匹配文件路径中出现“octocat”的代码 |
3.3.2、在用户或组织的仓库中搜索
语法 |
例子 |
user:defunkt extension:rb |
匹配来自@defunkt 的以.rb结尾的代码 |
org:github extension:js |
匹配来自 GitHub 的以.js结尾的代码 |
repo:mozilla/shumway extension:as |
匹配@mozilla 的 shumway 项目中以.as结尾的代码 |
3.3.3、按语言搜索
语法 |
例子 |
element language:xml size:100 |
匹配带有标记为 XML 且正好有 100 个字节的单词“element”的代码 |
display language:scss |
匹配带有单词“display”的代码,它被标记为 SCSS |
org:mozilla language:markdown |
匹配所有@mozilla 存储库中标记为 Markdown 的代码 |
3.3.4、按文件大小搜索
语法 |
例子 |
function size:>10000 language:python |
匹配用 Python 编写的大于 10 KB 的文件中带有“function”一词的代码 |
3.3.5、按文件名搜索
语法 |
例子 |
filename:linguist |
匹配名为“linguist”的文件 |
filename:.vimrc commands |
匹配带有 “commands” 一词的.vimrc文件。 |
3.4、搜索用户
官方文档:https://docs.github.com/zh/search-github/searching-on-github/searching-users
3.4.1、按帐户名称、全名或公共电子邮件搜索
语法 |
例子 |
user:octocat |
匹配用户名为“octocat”的用户 |
org:electron type:users |
匹配 Electron 组织的账户名 |
kenya in:login |
匹配用户名中包含“kenya”一词的用户 |
bolton in:name |
匹配真实姓名中包含单词“bolton”的用户 |
fullname:Nat Friedman |
匹配全名“Nat Friedman”的用户。注意:此搜索限定符对间距敏感。 |
data in:email |
将用户与电子邮件中的“data”一词匹配起来 |
3.4.2、按用户拥有的仓库数量搜索
语法 |
例子 |
repos:>9000 |
匹配存储库数量超过 9,000 的用户 |
bert repos:10…30 |
匹配用户名或真实姓名中包含“bert”一词且拥有 10 到 30 个存储库的用户 |
3.4.3、按创建用户帐户的时间搜索
语法 |
例子 |
created:<2011-01-01 |
匹配 2011 年之前加入的用户 |
created:>=2013-05-11 |
匹配在 2013 年 5 月 11 日或之后加入的用户 |
created:2013-03-06 location:london |
匹配于 2013 年 3 月 6 日加入且将其位置列为伦敦的用户 |
created:2010-01-01…2011-01-01 john in:login |
匹配在 2010 年到 2011 年之间加入且用户名中包含单词“john”的用户 |
3.4.4、按关注者数量搜索
语法 |
例子 |
followers:>=1000 |
匹配拥有 1,000 或更多关注者的用户 |
sparkle follower:1…10 |
匹配拥有 1 到 10 个关注者的用户,他们的名字中带有“sparkle”这个词 |