你真的知道如何在 GitHub 上高效搜索开源项目吗? 灰太狼 2021-12-03 12:39 178阅读 0赞 # 你真的知道如何在 GitHub 上高效搜索开源项目吗? # GitHub 的流行及其在开源世界的受欢迎程度自不必多言。再加上近来GitHub 官方又搞了个大新闻:[私有仓库也改为免费使用][Link 1],这在原来可是需要真金白银买的。可见微软收购后,依然没有改变 GitHub 的定位,甚至还更进一步。 花开两朵,各表一枝。我们今天想要聊的并不是 GitHub 多么重要,而是要说一下 GitHub 的搜索功能。 你在 GitHub 上搜索代码时,是怎样操作的呢?是不是也是像我这样,直接在搜索框里输入要检索的内容,然后不断在列表里翻页找自己需要的内容? ![640?wx\_fmt=png][640_wx_fmt_png] 或者是简单筛选下,在左侧加个语言的过滤项。 ![640?wx\_fmt=png][640_wx_fmt_png 1] 再或者改变一下列表的排序方式: ![640?wx\_fmt=png][640_wx_fmt_png 2] 这就是「全部」了吗? 一般的系统检索功能,都会有一个「**高级搜索**」的功能。需要在另外的界面里展开,进行二次搜索之类的。 GitHub 有没有类似的呢? 答案是「肯定的」。做为一个为万千工程师提供服务的网站,不仅要有,而且还要技术范儿。 如果我们自己开发一个类似的应用,会怎样实现呢? 带着思路,咱们一起来看看,GitHub 是怎样做的。 这里我们假设正要学习 Spring Cloud,要找一个 Spring Cloud 的 Demo 参考练手。 ![640?wx\_fmt=png][640_wx_fmt_png 3] **明确搜索仓库标题、仓库描述、README** GitHub 提供了便捷的搜索方式,可以限定只搜索仓库的标题、或者描述、README 等。 以 Spring Cloud 为例,一般一个仓库,大概是这样的 ![640?wx\_fmt=png][640_wx_fmt_png 4] 其中,红色箭头指的两个地方,分别是仓库的**名称**和**描述**。咱们可以直接限定关键字只查特定的地方。比如咱们只想查找仓库名称包含 Spring Cloud 的仓库,可以使用语法 **in:name** 关键词 ![640?wx\_fmt=png][640_wx_fmt_png 5] 如果想查找描述的内容,可以使用这样的方式: **in:descripton** 关键词 ![640?wx\_fmt=jpeg][640_wx_fmt_jpeg]这里就是搜索上面项目描述的内容。 一般项目,都会有个 README 文件,如果要查该文件包含特定关键词的话,我想你猜到了: **in:readme** 关键词 ![640?wx\_fmt=png][640_wx_fmt_png 6] **明确搜索 star、fork 数大于多少的** 一个项目 star 数的多少,一般代表该项目的受欢迎程度。虽然现在也有垃圾项目刷 star ,但毕竟是少数, star 依然是个不错的衡量标准。 stars: > 数字 关键字。 比如咱们要找 star 数大于 3000 的Spring Cloud 仓库,就可以这样: stars:>3000 spring cloud ![640?wx\_fmt=png][640_wx_fmt_png 7] 如果不加 >= 的话,是要精确找 star 数等于具体数字的,这个一般有点困难。 如果要找在指定数字区间的话,使用: stars: 10..20 关键词 fork 数同理,将上面的 stars 换成 fork,其它语法相同: ![640?wx\_fmt=png][640_wx_fmt_png 8] ![640?wx\_fmt=png][640_wx_fmt_png 9] **明确搜索仓库大小的** 比如你只想看个简单的 Demo,不想找特别复杂的且占用磁盘空间较多的,可以在搜索的时候直接限定仓库的 size 。 使用方式: size:>=5000 关键词 这里注意下,这个数字代表 K, 5000 代表着5M。 ![640?wx\_fmt=png][640_wx_fmt_png 10] **明确仓库是否还在更新维护** 我们在确认是否要使用一些开源产品、框架的时候,是否继续维护是很重要的一点。如果已经过时没人维护的东西,踩了坑就不好办了。而在 GitHub 上找项目的时候,不再需要每个都点到项目里看看最近 push 的时间,直接在搜索框即可完成。 元旦刚过,比如咱们要找临近年底依然在勤快更新的项目,就可以直接指定更新时间在哪个时间前或后的。 通过这样一条搜索 pushed:>2019-01-03 spring cloud 咱们就找到了 1 月 3 号之后,还在更新的项目。 ![640?wx\_fmt=png][640_wx_fmt_png 11] 你是想找指定时间之前或之后创建的仓库也是可以的,把 pushed 改成 created 就行。 ![640?wx\_fmt=png][640_wx_fmt_png 12] **明确搜索仓库的 LICENSE** 咱们经常使用开源软件,一定都知道,开源软件也是分不同的「门派」不同的 LICENSE。开源不等于一切免费,不同的许可证要求也大不相同。 2018年就出现了 Facebook 修改 React 的许可协议导致各个公司纷纷修改自己的代码,寻找替换的框架。 例如咱们要找协议是最为宽松的 Apache License 2 的代码,可以这样: license:apache-2.0 spring cloud ![640?wx\_fmt=png][640_wx_fmt_png 13] 其它协议就把 apache-2.0 替换一下即可,比如换成 mit 之类的。 ![640?wx\_fmt=png][640_wx_fmt_png 14] **明确搜索仓库的语言** 比如咱们就找 Java 的库, 除了像上面在左侧点击选择之外,还可以在搜索中过滤。像这样: language:java 关键词 ![640?wx\_fmt=png][640_wx_fmt_png 15] **明确搜索某个人或组织的仓库** 比如咱们想在 GitHub 上找一下某个大神是不是提交了新的功能,就可以指定其名称后搜索,例如咱们看下 Josh Long 有没有提交新的 Spring Cloud 的代码,可以这样使用: user:joshlong ![640?wx\_fmt=png][640_wx_fmt_png 16] 组合使用一下,把 Java 项目过滤出来,多个查询之间「空格」分隔即可。 **user:joshlong language:java** ![640?wx\_fmt=png][640_wx_fmt_png 17] 找某个组织的代码话,可以这样: org:spring-cloud 就可以列出具体org 的仓库。 ![640?wx\_fmt=png][640_wx_fmt_png 18] 【完】 [Link 1]: http://mp.weixin.qq.com/s?__biz=MjM5MjAwODM4MA==&mid=2650711991&idx=1&sn=171a5c91c1b1b4fe8cd315f61080ee54&chksm=bea6d66489d15f724bcf9e8645fe5f310408c1f10bda56e003d4d42d9ea04988b6e99fdfe525&scene=21#wechat_redirect [640_wx_fmt_png]: /images/20211203/c30832eef731405b84dc1e7d703f96e8.png [640_wx_fmt_png 1]: /images/20211203/eebee0dfc22f45d1898112ccd894a6f8.png [640_wx_fmt_png 2]: /images/20211203/e4b008c1e9e142aabcdf0f5d16ab75ab.png [640_wx_fmt_png 3]: /images/20211203/7307cf0fda8946fc93b5ed9f826d9ac0.png [640_wx_fmt_png 4]: /images/20211203/92b9a124b4f040fc990772b3587eb273.png [640_wx_fmt_png 5]: /images/20211203/d9d713b47bdb4e288aa11a84c9a73c38.png [640_wx_fmt_jpeg]: /images/20211203/11fa19cdcbe743faaced879feb56f592.png [640_wx_fmt_png 6]: /images/20211203/8b6121e3b2454801bcf62a7f548c1c72.png [640_wx_fmt_png 7]: /images/20211203/bd1b1f9fed28448e82ffd827d1719ee4.png [640_wx_fmt_png 8]: /images/20211203/de85ec599eae41d1a88b531a3cfe194e.png [640_wx_fmt_png 9]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy9QbjRTbTBSc0F1aFN2Wk1BdDJ6S2N4R1FOM2wxTlY0TGI0eWJORVZHbmFBdkVEd0VOS3pXMjdMVUtGREdaUEtjQm5lV3dUYVRwYUp5RzJDM2VtN2xpYlEvNjQwP3d4X2ZtdD1wbmc [640_wx_fmt_png 10]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy9QbjRTbTBSc0F1aFN2Wk1BdDJ6S2N4R1FOM2wxTlY0TExxeWY2Qlk0ck1mWTJMc1U4MU1pYkZqaWNLRExqTWppYjVSMjNoOHVvNkd0R0RZOE91ZldKZnBFdy82NDA_d3hfZm10PXBuZw [640_wx_fmt_png 11]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy84eVJ2OERpYmlhMnNyZWRRdXlkaWNxNWo2WEhyTFJIVGh2ZEdhMW1oeFZQRnRHcEE5M0JYbjFWRjM3ZU1XNndpYkxDTnYyUnV3Z1FGWGliY0VJNThmbGlhYlFSZy82NDA_d3hfZm10PXBuZw [640_wx_fmt_png 12]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy9QbjRTbTBSc0F1aFN2Wk1BdDJ6S2N4R1FOM2wxTlY0THpVemZvbDZxMUNPbFpZcGVZWHFlMGFpYTQ1RFh5aGNUUVc4dm9XdmliRkp2RWpmbWtoUHZDckVnLzY0MD93eF9mbXQ9cG5n [640_wx_fmt_png 13]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy84eVJ2OERpYmlhMnNyZWRRdXlkaWNxNWo2WEhyTFJIVGh2ZFVubHBaaDBhZmNWVlYxS0pxVUs2cEczRHZpYTF3SVdKNXJmVjdOMHVEZnRKNlNjOWpNMm9EcUEvNjQwP3d4X2ZtdD1wbmc [640_wx_fmt_png 14]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy9QbjRTbTBSc0F1aFN2Wk1BdDJ6S2N4R1FOM2wxTlY0TDhEUmtuUXUzRkI5ZVppY2lidk9TbFZyZ25sbEIzWGNHbnNydzR6Q2sxOWljMFFqWmtUUG9xRk1Xdy82NDA_d3hfZm10PXBuZw [640_wx_fmt_png 15]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy9QbjRTbTBSc0F1aFN2Wk1BdDJ6S2N4R1FOM2wxTlY0TEZWOTdIbHRRWWxOUEtEelg5N0sxTGwwRWljTHJCSXVXUXRnTHRRWWRGS2trTGNXS0dVZU1UZmcvNjQwP3d4X2ZtdD1wbmc [640_wx_fmt_png 16]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy84eVJ2OERpYmlhMnNyZWRRdXlkaWNxNWo2WEhyTFJIVGh2ZEZSSW1Eb3F6dGpOMHlKYWM0SUE5cU9tdTVzcnRqZ0YwZ3ROcG52ZU1Pd2lhMVpNN2pTbmljQm9RLzY0MD93eF9mbXQ9cG5n [640_wx_fmt_png 17]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy84eVJ2OERpYmlhMnNyZWRRdXlkaWNxNWo2WEhyTFJIVGh2ZFM3S2M3cTgwRkZpYWliaWJibWJvZjBNNkt5clJpYjlHZTc0ekFNUmhpY1pUUGdmc1VET2o0cGJsa3RBLzY0MD93eF9mbXQ9cG5n [640_wx_fmt_png 18]: https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X3BuZy84eVJ2OERpYmlhMnNyZWRRdXlkaWNxNWo2WEhyTFJIVGh2ZDRGelMxY3JpYk1QUWdYWjBLb05IeHVMc0tDb2tFWkFualQ5RTNBTE92RllmbXZaMVVTVjdzSHcvNjQwP3d4X2ZtdD1wbmc
还没有评论,来说两句吧...