zoukankan      html  css  js  c++  java
  • [Ramda] Count Words in a String with Ramda's countBy and invert

    You can really unlock the power of ramda (and functional programming in general) when you combine functions. Counting words in a string may seem like a relatively difficult task, but ramda makes it easy by providing a countBy function. This lesson walks through using the countBy to count words in a string.

    const text = `
    'have no fear of this mess,'
    said the cat in the hat.
    'i always pick up all my playthings
    and so...
    i will show you another
    good trick that i know!'
    
    then we saw him pick up all the things that were down.
    he picked up the cake,
    and the rake, and the gown,
    and the milk, and the strings,
    and the books, and the dish,
    and the fan, and the cup,
    and the ship, and the fish.
    and he put them away.
    then he said, 'that is that.'
    and then he was gone
    with a tip of his hat.
    
    then our mother came in
    and she said to us two,
    'did you have any fun?
    tell me.  what did you do?'
    
    and sally and i did not know
    what to say.
    should we tell her
    the things that went on there that day?
    
    should we tell her about it?
    now, what SHOULD we do?
    well...
    what would YOU do
    if your mother asked YOU?`
    
    console.clear()
    
    const countWords = R.compose(
      R.map(R.sortBy(R.identity)),
      R.invert,
      R.countBy(R.identity),
      R.map(R.toLower),
      R.match(/w+/g)
    );
    const res = countWords(text);
    console.log(res);
    /*
    
    {
      1: ["a", "about", "always", "another", "any", "asked", "away", "books", "cake", "came", "cat", "cup", "day", "dish", "down", "fan", "fear", "fish", "fun", "gone", "good", "gown", "him", "his", "if", "is", "it", "me", "mess", "milk", "my", "no", "not", "now", "on", "our", "picked", "playthings", "put", "rake", "sally", "saw", "say", "she", "ship", "show", "so", "strings", "them", "there", "this", "tip", "trick", "two", "us", "was", "well", "went", "were", "will", "with", "would", "your"],
      15: ["the"],
      16: ["and"],
      2: ["all", "hat", "have", "her", "in", "know", "mother", "of", "pick", "things", "to"],
      3: ["did", "do", "said", "should", "tell", "up"],
      4: ["he", "i", "then", "we", "what"],
      5: ["you"],
      6: ["that"]
    }
    */
  • 相关阅读:
    ajax处理响应(三)
    ajax起步 (二)
    ajax的使用(一)
    css相关用法
    vue 实例的生命周期
    vue中computed与watch的异同
    文本显示,单行超出和多行超出显示省略号
    vue+mui+html5+ plus开发的混合应用底部导航的显示与隐藏
    addEventListener()与removeEventListener(),追加事件和删除追加事件
    原生js中获取this与鼠标对象以及vue中默认的鼠标对象参数
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6378718.html
Copyright © 2011-2022 走看看