1、前言
GitHub的搜索功能绝不仅仅是单纯匹配你输入的内容,而是有如下匹配规则。
本文参考自GitHub官方文档。
GitHub官方文档:https://docs.github.com/en
本文第3点总结了目前GitHub搜索最常用的技巧,根据平时搜索的内容分为了搜索存储库、搜索主题、搜索代码和搜索用户四个小点,可以根据自己想要的搜索内容定位到每个小点,同时第2点总结了将你搜索到的结果按照什么排序顺序排序,包括交互排序、反应排序、作者日期排序、提交者日期排序、更新日期排序等。
2、排序搜索结果
2.1. 按交互排序
| 语法 | 
例子 | 
| org:github sort:interactions | 
匹配 GitHub 拥有的存储库中的问题,按反应和评论的最高组合数排序 | 
| org:github sort:interactions-asc | 
匹配 GitHub 拥有的存储库中的问题,按最少的反应和评论组合数排序 | 
2.2. 按反应排序
| 语法 | 
例子 | 
| org:github sort:reactions | 
匹配 GitHub 拥有的存储库中的问题,按最高反应数排序。 | 
| org:github sort:reactions-asc | 
匹配 GitHub 拥有的存储库中的问题,按反应数量升序排序(从最少到最多) | 
| org:github sort:reactions-+1 | 
匹配 GitHub 拥有的存储库中的问题,按最多点赞 (👍) 反应排序 | 
| org:github sort:reactions- -1 | 
匹配 GitHub 拥有的存储库中的问题,按最多 (👎) 反应排序 | 
| org:github sort:reactions-smile | 
匹配 GitHub 拥有的存储库中的问题,按最多笑 (😄) 反应排序 | 
| org:github sort:reactions-tada | 
匹配 GitHub 拥有的存储库中的问题,按大多数欢呼 (🎉) 反应排序 | 
| org:github sort:reactions-heart | 
匹配 GitHub 拥有的存储库中的问题,按大多数心脏 (❤️) 反应排序 | 
2.3. 按作者日期排序
| 语法 | 
例子 | 
| org:github sort:author-date feature | 
匹配 GitHub 拥有的存储库中包含单词“feature”的提交,按作者日期降序排序 | 
| org:github sort:author-date-asc feature | 
匹配 GitHub 拥有的存储库中包含单词“feature”的提交,按作者日期升序排序 | 
2.4. 按提交者日期排序
| 语法 | 
例子 | 
| org:github sort:committer-date | 
匹配 GitHub 拥有的存储库中包含“功能”一词的提交,按提交者日期降序排序 | 
| org:github sort:committer-date-asc | 
匹配 GitHub 拥有的存储库中包含“功能”一词的提交,按提交者日期升序排序 | 
2.5. 按更新日期排序
| 语法 | 
例子 | 
| sort:updated feature | 
匹配包含“feature”一词的存储库,按最近更新日期排序 | 
| sort:updated-asc feature | 
匹配包含单词“feature”的存储库,按最近更新日期排序 | 
3、搜索范围
3.1. 搜索存储库
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 的存储库。 | 
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. 按分叉数搜索
| 语法 | 
例子 | 
| 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. 搜索主题
3.2.1. 使用搜索限定符缩小搜索范围
3.3. 搜索代码
| 序号 | 
代码搜索的注意事项:由于搜索代码的复杂性,对搜索的执行方式有一些限制 | 
| 1 | 
必须登录 GitHub 上的用户帐户才能在所有公共存储库中搜索代码 | 
| 2 | 
只有当分叉的星数多于父存储库时,分叉中的代码才可搜索。星号少于父存储库的分叉不会为代码搜索编制索引。要在搜索结果中包含星数多于父级的分叉,需要将fork:true或添加fork:only到查询中。有关更多信息,请参阅“在分叉中搜索” | 
| 3 | 
仅对默认分支进行索引以进行代码搜索 | 
| 4 | 
只能搜索小于 384 KB 的文。 | 
| 5 | 
只能搜索少于 500,000 个文件的存储库 | 
| 6 | 
只有在去年有活动或在搜索结果中返回的存储库才可搜索 | 
| 7 | 
除了filename搜索之外,在搜索源代码时,必须始终包含至少一个搜索词。例如,搜索language:javascript无效,而搜索无效amazing language:javascript | 
| 8 | 
搜索结果最多可以显示来自同一个文件的两个片段,但文件中可能会有更多的结果 | 
| 9 | 
不能在搜索查询中使用以下通配符:. , : ; / \ ` ’ “ = * ! ? # $ & + ^ | 
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. 搜索用户
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”这个词 |