npm 包 Miller 使用教程

AI 编程助手,豆包旗下的编程助手,提供智能补全、智能预测、智能问答等能力,节省开发时间,释放脑海中的创造力,支持 VSCode,点击体验 AI

前言

所谓“万物皆可编程”,这也包括前端工具的编写。不少开发者在工作中会使用到一些工具来简化流程或者提高效率。而 npm 是前端开发工具包管理的重要平台之一,在 npm 库中有很多优秀的工具包,今天我们就来介绍一个比较有用的工具包——miller。

miller 是什么

miller 是一个命令行工具,是一个用来处理文本文件的工具。它支持自定义一些简单的文本转化规则,支持 Python 和 awk 操作。更多关于 miller 的信息可以参考官方文档:https://github.com/johnkerl/miller

使用 miller

安装

安装 miller 可以通过 npm 来完成:

--- ------- -- ------

使用说明

命令行操作

使用 miller 可以通过以下的操作:

列出文件列表:

--- ----- --- -------------

做一些汇总:

--- ----- ------ -- ----------------------- -- --------------- -------------

替换文本内容:

--- --- -- --- ------------- - --- --- -- -- --- - --- --- --------- -------------

配置文件操作

miller 还支持通过配置文件进行操作,相关的用法如下:

创建一个配置文件:

--- --- -- --- ------ -- --------- ------------ ---- ------------- --------

运行配置文件:

--- ----- ------ -- -------- -------------

实例

下面是一个示例,如何使用 miller 完成根据数据计算市场价格前 10 的股票名称。我们可以通过以下步骤来完成:

1. 通过计算出市盈率,并求出当前市盈率最大的前 10 个公司的名称

我们从一个 csv 文件,包含股票名称、市值、利润、市盈率信息,来展示如何使用 miller 实现这个需求。

我们首先通过以下命令,从 csv 文件中提取出市值和利润两列数据:

--- ----- --- -- ---------------------- --------

接下来,我们计算市盈率,并根据市盈率排序:

--- ----- --- --------- - ------------ - -- - ------------------------ - -- -------- - --- ----- ---- -- -- -------

排序后,我们需要选取前 10 个公司,也可以通过以下代码来实现:

--- -- ----- ---- -- -- -------- - --- ----- --- -- ----

可以看到,上述代码中,通过 mlr --csv head -n 10 选取了前 10 个公司,然后通过 mlr --csv cut -f name 选取其中的股票名称。

2. 通过配置文件实现

miller 还支持通过配置文件实现,即我们可以把上述的命令写在配置文件中,然后执行配置文件来完成任务。

我们创建一个配置文件 my-clause:

------- - ------------------------
-- - ----
-- --- -- --- -
  --------------- - -
-
-- --- - --- -
  --- --- - -- --------- -
    -- ------ -- -- -
      -- - -
    -
  -
-

然后通过以下命令来执行:

--- ----- ------ -- --------- -------- - --- ----- --- -- ----

总结

通过本篇文章,我们了解了 miller 的基本使用方法,并且通过一个示例,展示了如何使用 miller 解决问题。miller 可以通过命令行或配置文件的方式使用,使用上还是比较方便的。是前端工具包中的一个不错的工具,值得我们一试。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/60066f481d8e776d080410d2


猜你喜欢

  • npm 包 object-iterable 使用教程

    简介 object-iterable 是一个基于 ES6 iterable 协议实现的工具,可以将对象转化为可遍历的 Iterable 类型。这个工具包提供了一些辅助函数,可以使用对象的键或值遍历对象...

    4 年前
  • npm 包 object-iterator 使用教程

    在前端开发的过程中,我们经常需要遍历对象并对其进行处理,此时 object-iterator 这个 npm 包能够帮我们快速地完成这个过程。本篇文章将重点介绍 npm 包 object-iterato...

    4 年前
  • npm 包 object-join 使用教程

    介绍 object-join 是一个可以用于 JavaScript 对象合并的 npm 包。很多开发者在开发过程中经常需要对对象进行操作,比如对对象进行合并,这就需要使用到这款工具。

    4 年前
  • npm 包 object-key 使用教程

    在前端开发中,操作 JavaScript 对象是非常常见的。面对复杂的对象结构,我们常常需要找到特定的键值对进行访问或操作。这时候,npm 上的 object-key 包就提供了一个非常实用的解决方案...

    4 年前
  • npm包 object-key-filter 使用教程

    什么是object-key-filter Object-key-filter是一个可以通过保留或删除一个对象的键来对其进行过滤的npm包。该包主要用于JavaScript应用程序中操作对象的键。

    4 年前
  • npm 包 object-key-map 使用教程

    前言 在前端开发中,我们经常会遇到需要将某些对象或数据进行转换或处理的情况。而 object-key-map 这个 npm 包则提供了一种方便快捷的解决方案,可以轻松地进行对象中键名的转换。

    4 年前
  • npm 包 object-key-transform 使用教程

    在前端开发中,常常需要对一个对象的属性进行转换。比如,前端需要将一个API返回的数据对象的属性名(key)从下划线式(like_this)转为驼峰式(likeThis)或反之。

    4 年前
  • npm 包 object-keys-modifier 使用教程

    引言 在前端开发中,有很多时候需要对 JavaScript 对象进行操作。然而,在实际情况中,我们常常需要对对象进行深度操作或者对对象的属性进行修改。这时候,如果手动进行操作的话,会很繁琐且容易出错。

    4 年前
  • npm 包 object-keys-to-array 使用教程

    简介 在前端开发中,我们常常需要处理返回的对象,将对象中的 key 转为数组。 npm 包 object-keys-to-array 就是一个非常实用的工具包,可以将对象中的 key 转为数组。

    4 年前
  • npm 包 OAuth2Boom 使用教程

    OAuth2Boom 是一个 Node.js 的 NPM 包,用于在 Express 和 Hapi 应用程序中处理 OAuth2 错误和异常。在这篇文章中,我们将介绍如何使用该包,并以示例代码的形式演...

    4 年前
  • npm 包 oauth2orize-device-code 使用教程

    前言 OAuth 2.0 是用于 API 访问授权的行业标准协议。 OAuth 2.0 授权过程中,用户需要使用授权服务器颁发的令牌来访问受保护的资源。然而,在设备上进行认证流程时存在问题,尤其对于小...

    4 年前
  • npm 包 oauth2orize-chain 使用教程

    简介 oauth2orize-chain 是一个基于 OAuth 2.0 协议的 Node.js 包,它可以帮助开发者快速实现类似 Facebook 和 Google 这样的第三方登录/授权功能。

    4 年前
  • npm 包 oauth2orize-facebook 使用教程

    简介 OAuth2 是一种常用的身份验证协议,使用户可以授权他们的信息被第三方应用程序使用,而无需提供他们的密码。OAuth2 的工作流程涉及许多参与方,包括用户、授权服务器和受保护资源服务器。

    4 年前
  • npm 包 oauth2orize-fprm 使用教程

    npm 包 oauth2orize-fprm 使用教程 在前端开发中,使用第三方授权服务进行身份认证和授权已经成为一种常见的做法。而 oauth2orize-fprm 是一个能够帮助我们实现 oaut...

    4 年前
  • npm 包 object-iron 使用教程

    简介 object-iron 是一个 npm 包,它提供了一种加密和解密 JavaScript 对象的方法。它可以用于保护敏感数据的传输和存储,以及防止数据泄露。本文将介绍如何使用 object-ir...

    4 年前
  • npm 包 nuxt-sass-resources-loader 使用教程

    前言 在进行前端开发的时候,我们常常需要使用到 SASS(Syntactically Awesome Style Sheets)预处理器,它通过增强 CSS 的能力可以使得样式编写更加简单、优雅和易于...

    4 年前
  • npm 包 nuxt-seo-module 使用教程

    介绍 nuxt-seo-module 是一个用于快速搭建基于 SEO 的应用的 npm 包。该包可以帮助前端开发人员快速地构建出对搜索引擎友好的 Web 应用。在使用该包时,可以将网站的 SEO 优化...

    4 年前
  • npm 包 nuxt-sprite-svg-inline 使用教程

    介绍 nuxt-sprite-svg-inline 是一个可以将多张 SVG 图片合并成一张雪碧图的 npm 包。它提供了非常方便的工具,可以让前端工程师在开发过程中更加高效地使用 SVG 图片,以及...

    4 年前
  • npm 包 nuxt-stylus-resources-loader 使用教程

    在前端开发中,使用类似 Vue、Nuxt 这样的框架进行开发,有时候需要使用一些共享的样式或 mixin,如果每个组件都单独引入,不仅会增加代码冗余,还会影响加载速度。

    4 年前
  • npm 包 nuxtdown 使用教程

    简介 nuxtdown 是一个基于 Nuxt.js 的 Markdown 静态网站生成器,它可以把 Markdown 文件直接转换成静态网站,提供了丰富的自定义选项及插件系统,是一个非常好用的工具。

    4 年前

相关推荐

    暂无文章