码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • es查询响应结果中获取某些字段的值


            有时候使用es查询出的结果包含多个字段,如果数据中仅仅包含几个字段时,我们是很容易挑出自己需要的字段值,但是如果数据中包含几十或者几百甚至更多时,尤其是数据中嵌套好多层时,不容易直接挑取出需要的值,这时候可以借助程序直接查找出来。或者针对性的直接查询时就限定条件查询某些字段的值。

    直接从es中查询出的示例数据:

    1. {
    2. "took": 918,
    3. "timed_out": false,
    4. "_shards": {
    5. "total": 1,
    6. "successful": 1,
    7. "skipped": 0,
    8. "failed": 0
    9. },
    10. "hits": {
    11. "total": {
    12. "value": 4,
    13. "relation": "eq"
    14. },
    15. "max_score": 1.0,
    16. "hits": [{
    17. "_index": "test",
    18. "_type": "user",
    19. "_id": "QHi1UoIBpyNh4YQ4T1Sq",
    20. "_score": 1.0,
    21. "_source": {
    22. "id": 1001,
    23. "name": "张三",
    24. "age": 20,
    25. "sex": "男",
    26. "grade": {
    27. "Chinese": 99,
    28. "Math": 98,
    29. "English": 96
    30. }
    31. }
    32. },
    33. {
    34. "_index": "test",
    35. "_type": "user",
    36. "_id": "1002",
    37. "_score": 1.0,
    38. "_source": {
    39. "id": 1002,
    40. "name": "李四",
    41. "age": 23,
    42. "sex": "女",
    43. "grade": {
    44. "Chinese": 98,
    45. "Math": 99,
    46. "English": 97
    47. }
    48. }
    49. },
    50. {
    51. "_index": "test",
    52. "_type": "user",
    53. "_id": "1003",
    54. "_score": 1.0,
    55. "_source": {
    56. "id": 1003,
    57. "name": "王五",
    58. "age": 27,
    59. "sex": "男",
    60. "grade": {
    61. "Chinese": 93,
    62. "Math": 90,
    63. "English": 99
    64. }
    65. }
    66. },
    67. {
    68. "_index": "test",
    69. "_type": "user",
    70. "_id": "1004",
    71. "_score": 1.0,
    72. "_source": {
    73. "id": 1004,
    74. "name": "赵六",
    75. "age": 29,
    76. "sex": "女",
    77. "grade": {
    78. "Chinese": 100,
    79. "Math": 95,
    80. "English": 94
    81. }
    82. }
    83. }
    84. ]
    85. }
    86. }

    使用python打印出需要的字段值:

    1. import json
    2. import jmespath
    3. with open('text.txt', 'r', encoding='utf-8') as f:
    4. data = f.read()
    5. json_data = json.loads(data)
    6. # print(json_data)
    7. sources = json_data.get('hits').get('hits')
    8. # print(sources)
    9. for source in sources:
    10. # print(source)
    11. data = source.get('_source')
    12. print(data)
    13. valid_fields = '{name: name, Chinese_grade: grade.Chinese}'
    14. ret = jmespath.search(valid_fields, data)
    15. print(ret)

    运行结果:

    注意:使用json.load()时,会把文本中的fase、true直接变为False、True

    参考博文:

    python中jmespath库用法详解_IT之一小佬的博客-CSDN博客_jmespath python

  • 相关阅读:
    element + vue 批量调后端接口loading显示
    什么是会话劫持以及如何阻止它
    蓝牙耳机哪个音质好?1000左右音质最好的耳机
    竞赛开源项目汇总
    嵌入式软件学习进阶
    为开发GPT-5,OpenAI向微软寻求新融资
    【GIT】:一文快速了解什么是GIT
    无胁科技-TVD每日漏洞情报-2022-9-8
    春季高考更名为职教高考,从中职到大学本科研究生升学通道打通
    陈芳允于1971年提出双星定位
  • 原文地址:https://blog.csdn.net/weixin_44799217/article/details/128160889
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号