• 使用LlamaIndex构建自己的PandasAI


    推荐:使用 NSDT场景编辑器 快速搭建3D应用场景

    Pandas AI 是一个 Python 库,它利用生成 AI 的强大功能来增强流行的数据分析库 Pandas。只需一个简单的提示,Pandas AI 就可以让你执行复杂的数据清理、分析和可视化,而这以前需要很多行代码。

    除了处理数字之外,Pandas AI还理解自然语言。您可以用简单的英语询问有关数据的问题,它将以日常语言提供摘要和见解,使您免于破译复杂的图形和表格。

    在下面的示例中,我们提供了一个 Pandas 数据帧,并要求生成 AI 创建条形图。结果令人印象深刻。

    pandas_ai.run(df, prompt='Plot the bar chart of type of media for each year release, using different colors.')

    使用LlamaIndex构建自己的PandasAI

    注意:代码示例来自 Pandas AI:您的生成式 AI 驱动的数据分析指南教程。

    在这篇文章中,我们将使用LlamaIndex来创建类似的工具,这些工具可以理解Pandas数据框架并产生复杂的结果,如上所示。

    LlamaIndex支持通过聊天和代理对数据进行自然语言查询。它允许大型语言模型大规模解释私有数据,而无需对新数据进行重新训练。它将大型语言模型与各种数据源和工具集成在一起。LlamaIndex是一个数据框架,只需几行代码即可轻松创建带有PDF应用程序的聊天。

    建立

    您可以使用该命令安装 Python 库。pip

    pip install llama-index

    默认情况下,LlamaIndex使用OpenAI模型进行文本生成以及检索和嵌入。为了轻松运行代码,我们必须设置 .我们可以在新的 API 令牌页面上免费注册并获取 API 密钥。gpt-3.5-turbotext-embedding-ada-002OPENAI_API_KEY

    1. import os
    2. os.environ["OPENAI_API_KEY"] = "sk-xxxxxx"

    它们还支持Anthropic,Hugging Face,PaLM和更多模型的集成。您可以通过阅读模块的文档来了解有关它的所有信息。

    熊猫查询引擎

    让我们进入创建自己的PandasAI的主要主题。安装库并设置 API 密钥后,我们将创建一个简单的城市数据帧,以城市名称和人口作为列。

    1. import pandas as pd
    2. from llama_index.query_engine.pandas_query_engine import PandasQueryEngine
    1. df = pd.DataFrame(
    2. {"city": ["New York", "Islamabad", "Mumbai"], "population": [8804190, 1009832, 12478447]}
    3. )

    使用 ,我们将创建一个查询引擎来加载数据帧并为其编制索引。PandasQueryEngine

    之后,我们将编写一个查询并显示响应。

    1. query_engine = PandasQueryEngine(df=df)
    2. response = query_engine.query(
    3. "What is the city with the lowest population?",
    4. )

    如我们所见,它开发了 Python 代码,用于在数据帧中显示人口最少的城市。

    1. > Pandas Instructions:
    2. ```
    3. eval("df.loc[df['population'].idxmin()]['city']")
    4. ```
    5. eval("df.loc[df['population'].idxmin()]['city']")
    6. > Pandas Output: Islamabad

    而且,如果你打印回复,你会得到“伊斯兰堡”。这很简单,但令人印象深刻。您不必提出自己的逻辑或围绕代码进行实验。只需输入问题,您就会得到答案。

    print(response)
    Islamabad

    您还可以使用响应元数据打印结果背后的代码。

    print(response.metadata["pandas_instruction_str"])
    eval("df.loc[df['population'].idxmin()]['city']")

    全球优酷统计分析

    在第二个示例中,我们将从 Kaggle 加载 2023 年全球 YouTube 统计数据集并执行一些基本面分析。这是从简单示例迈出的一步。

    我们将用于将数据集加载到查询引擎中。然后我们将编写提示,仅显示具有缺失值和缺失值数量的列。read_csv

    1. df_yt = pd.read_csv("Global YouTube Statistics.csv")
    2. query_engine = PandasQueryEngine(df=df_yt, verbose=True)
    3. response = query_engine.query(
    4. "List the columns with missing values and the number of missing values. Only show missing values columns.",
    5. )
    1. > Pandas Instructions:
    2. ```
    3. df.isnull().sum()[df.isnull().sum() > 0]
    4. ```
    5. df.isnull().sum()[df.isnull().sum() > 0]
    6. > Pandas Output: category 46
    7. Country 122
    8. Abbreviation 122
    9. channel_type 30
    10. video_views_rank 1
    11. country_rank 116
    12. channel_type_rank 33
    13. video_views_for_the_last_30_days 56
    14. subscribers_for_last_30_days 337
    15. created_year 5
    16. created_month 5
    17. created_date 5
    18. Gross tertiary education enrollment (%) 123
    19. Population 123
    20. Unemployment rate 123
    21. Urban_population 123
    22. Latitude 123
    23. Longitude 123
    24. dtype: int64

    现在,我们将直接询问有关流行频道类型的问题。在我看来,LlamdaIndex查询引擎非常准确,还没有产生任何幻觉。

    1. response = query_engine.query(
    2. "Which channel type have the most views.",
    3. )
    1. > Pandas Instructions:
    2. ```
    3. eval("df.groupby('channel_type')['video views'].sum().idxmax()")
    4. ```
    5. eval("df.groupby('channel_type')['video views'].sum().idxmax()")
    6. > Pandas Output: Entertainment
    7. Entertainment

    最后,我们将要求它可视化barchat,结果是惊人的。

    1. response = query_engine.query(
    2. "Visualize barchat of top ten youtube channels based on subscribers and add the title.",
    3. )
    1. > Pandas Instructions:
    2. ```
    3. eval("df.nlargest(10, 'subscribers')[['Youtuber', 'subscribers']].plot(kind='bar', x='Youtuber', y='subscribers', title='Top Ten YouTube Channels Based on Subscribers')")
    4. ```
    5. eval("df.nlargest(10, 'subscribers')[['Youtuber', 'subscribers']].plot(kind='bar', x='Youtuber', y='subscribers', title='Top Ten YouTube Channels Based on Subscribers')")
    6. > Pandas Output: AxesSubplot(0.125,0.11;0.775x0.77)

    使用LlamaIndex构建自己的PandasAI

    通过简单的提示和查询引擎,我们可以自动化数据分析并执行复杂的任务。喇嘛指数还有更多。我强烈建议您阅读官方文档并尝试构建令人惊叹的东西。

    结论

    总之,LlamaIndex是一个令人兴奋的新工具,它允许开发人员创建自己的PandasAI - 利用大型语言模型的强大功能进行直观的数据分析和对话。通过使用 LlamaIndex 索引和嵌入数据集,您可以对私有数据启用高级自然语言功能,而不会影响安全性或重新训练模型。

    这只是一个开始,使用LlamaIndex,您可以构建文档,聊天机器人,自动化AI,知识图谱,AI SQL查询引擎,全栈Web应用程序的问答,并构建私有生成AI应用程序。

    原文链接:使用LlamaIndex构建自己的PandasAI (mvrlink.com)

  • 相关阅读:
    链表题目 : 链表的中间结点 与 链表中倒数第k个结点(leetcode 和 牛客)
    OceanBase本周活动|从0到1数据库内核实战教程;对话ACE第五期;Meetup广州站
    C. Complementary XOR CodeTON Round 3 (Div. 1 + Div. 2, Rated, Prizes)
    408知识框架总结——操作系统
    OKR,为什么我喜欢他们
    “深入理解SpringMVC的注解驱动开发“
    2022年安徽省技术创新示范企业奖励补贴标准以及申报条件(附合肥市各地区奖补标准)
    神经网络可以解决的问题,神经性修复治疗方法
    5G工业专网架构和关键技术探讨
    seata-分布式事务
  • 原文地址:https://blog.csdn.net/ygtu2018/article/details/132807967