groupby 和 select 来自本机对象的最大 id
groupby and select max id from object in react native
如何 groupby
和 select 在 React Native 中从对象获取最大 ID。
那只是一个虚拟数据,用于向您解释我的对象的外观
[
{"name": "alex", "subject": "english" "student_id": "1"},
{"name": "hales", "subject": "science" "student_id": "2"},
{"name": "joss", "subject": "english" "student_id": "3"},
{"name": "alexandra", "subject": "science" "student_id": "4"},
{"name": "mark", "subject": "math" "student_id": "5"},
]
首先,我想按学科分组,然后 select 具有最大 ID 的学生,所以我的输出应该是这样的
[
{"name": "joss", "subject": "english" "student_id": "3"},
{"name": "alexandra", "subject": "science" "student_id": "4"},
{"name": "mark", "subject": "math" "student_id": "5"},
]
到目前为止我已经尝试过的是
const result = myobject.reduce(function (r, a) {
r[a.case_id] = r[a.case_id] || [];
r[a.case_id].push(a);
return r;
}, Object.create(null));
使用上面的代码我可以分组但无法获得最大 ID 那么我该如何实现呢?
您可以按 subject
分组,如果 student_id
更大,则替换该值。
作为结果从对象中获取值。
const
data = [{ name: "alex", subject: "english", student_id: "1" }, { name: "hales", subject: "science", student_id: "2" }, { name: "joss", subject: "english", student_id: "3" }, { name: "alexandra", subject: "science", student_id: "4" }, { name: "mark", subject: "math", student_id: "5" }],
result = Object.values(data.reduce((r, o) => {
if (!r[o.subject] || +r[o.subject].student_id < +o.student_id) {
r[o.subject] = o;
}
return r;
}, Object.create(null)));
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
lodash 如果不介意的话。这似乎是一种简洁明了的理解方式
const data = [{ name: "alex", subject: "english", student_id: "1" }, { name: "hales", subject: "science", student_id: "2" }, { name: "joss", subject: "english", student_id: "3" }, { name: "alexandra", subject: "science", student_id: "4" }, { name: "mark", subject: "math", student_id: "5" }];
const result = _.chain(data)
.groupBy('subject')
.values()
.map((group) => _.maxBy(group, 'student_id'))
.value();
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.21/lodash.min.js" integrity="sha512-WFN04846sdKMIP5LKNphMaWzU7YpMyCU245etK3g/2ARYbPK9Ub18eG+ljU96qKRCWh+quCY7yefSmlkQw1ANQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
如何 groupby
和 select 在 React Native 中从对象获取最大 ID。
那只是一个虚拟数据,用于向您解释我的对象的外观
[
{"name": "alex", "subject": "english" "student_id": "1"},
{"name": "hales", "subject": "science" "student_id": "2"},
{"name": "joss", "subject": "english" "student_id": "3"},
{"name": "alexandra", "subject": "science" "student_id": "4"},
{"name": "mark", "subject": "math" "student_id": "5"},
]
首先,我想按学科分组,然后 select 具有最大 ID 的学生,所以我的输出应该是这样的
[
{"name": "joss", "subject": "english" "student_id": "3"},
{"name": "alexandra", "subject": "science" "student_id": "4"},
{"name": "mark", "subject": "math" "student_id": "5"},
]
到目前为止我已经尝试过的是
const result = myobject.reduce(function (r, a) {
r[a.case_id] = r[a.case_id] || [];
r[a.case_id].push(a);
return r;
}, Object.create(null));
使用上面的代码我可以分组但无法获得最大 ID 那么我该如何实现呢?
您可以按 subject
分组,如果 student_id
更大,则替换该值。
作为结果从对象中获取值。
const
data = [{ name: "alex", subject: "english", student_id: "1" }, { name: "hales", subject: "science", student_id: "2" }, { name: "joss", subject: "english", student_id: "3" }, { name: "alexandra", subject: "science", student_id: "4" }, { name: "mark", subject: "math", student_id: "5" }],
result = Object.values(data.reduce((r, o) => {
if (!r[o.subject] || +r[o.subject].student_id < +o.student_id) {
r[o.subject] = o;
}
return r;
}, Object.create(null)));
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
lodash 如果不介意的话。这似乎是一种简洁明了的理解方式
const data = [{ name: "alex", subject: "english", student_id: "1" }, { name: "hales", subject: "science", student_id: "2" }, { name: "joss", subject: "english", student_id: "3" }, { name: "alexandra", subject: "science", student_id: "4" }, { name: "mark", subject: "math", student_id: "5" }];
const result = _.chain(data)
.groupBy('subject')
.values()
.map((group) => _.maxBy(group, 'student_id'))
.value();
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.21/lodash.min.js" integrity="sha512-WFN04846sdKMIP5LKNphMaWzU7YpMyCU245etK3g/2ARYbPK9Ub18eG+ljU96qKRCWh+quCY7yefSmlkQw1ANQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>