lodashでオブジェクトのキーをフィルターする方法は?


178

一部のキーを持つオブジェクトがあり、一部のキーのみを値とともに保持しますか?

私が試したfilter

const data = {
  aaa: 111,
  abb: 222,
  bbb: 333
};

const result = _.filter(data, (value, key) => key.startsWith("a"));

console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>

しかし、それは配列を出力します:

[111、222]

それは私が望むものではありません。

ロダッシュでそれを行う方法?または、lodashが機能しない場合は何か他にありますか?

回答:


285

Lodashには、_.pickByまさにあなたが探しているものを実行する機能があります。

var thing = {
  "a": 123,
  "b": 456,
  "abc": 6789
};

var result = _.pickBy(thing, function(value, key) {
  return _.startsWith(key, "a");
});

console.log(result.abc) // 6789
console.log(result.b)   // undefined
<script src="https://cdn.jsdelivr.net/lodash/4.16.4/lodash.min.js"></script>


9
これはlodashバージョン4では壊れているようです。新しい_.pickBy述語は、キーではなく値でのみ呼び出されます。Boo :( ..._。pickと_.pickByをチェーンできると思います(実際には、同じ機能を取得することはできません)
SDK

3
最新Lodashのように、これはもはや働かない、ちょうどFYI
Eudisデュラン

8
@EudisDuranを使用する必要があります.pickBy
apfelbox

最新バージョンで修正されているようです

39

フィルターをomitByに変更するだけです

const data = { aaa: 111, abb: 222, bbb: 333 };
const result = _.omitBy(data, (value, key) => !key.startsWith("a"));
console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>


これはまだ配列を出力しませんか?
Mr_Green

4
ありがとう!そして、私たちは使用できると思います_.pick
Freewind

これは、もはや最新lodashのように動作しない、ちょうどFYI
Eudisデュラン

18

lodash4.x を使用した例を次に示します。

const data = {
  aaa: 111,
  abb: 222,
  bbb: 333
};

const result = _.pickBy(data, (value, key) => key.startsWith("a"));

console.log(result);
// Object { aaa: 111, abb: 222 }
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>
<strong>Open your javascript console to see the output.</strong>


4

これをかなり読みやすく効率的な方法で解決する非lodashの方法:

function filterByKeys(obj, keys = []) {
  const filtered = {}
  keys.forEach(key => {
    if (obj.hasOwnProperty(key)) {
      filtered[key] = obj[key]
    }
  })
  return filtered
}

const myObject = {
  a: 1,
  b: 'bananas',
  d: null
}

const result = filterByKeys(myObject, ['a', 'd', 'e']) // {a: 1, d: null}
console.log(result)

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.