Skip to content

Latest commit

 

History

History
253 lines (187 loc) · 9.34 KB

README.md

File metadata and controls

253 lines (187 loc) · 9.34 KB

File Interaction Script Tool - 专为 LLM 交互设计的文件交互脚本工具

简介

FIS (File Interaction Script) 是一种用于描述项目文件结构的文本格式,旨在简化与大型语言模型 (LLM) 的交互,实现更高效的项目迭代。它提供了一种结构化的方式,让您能够:

  • 生成项目结构描述文件: 从一个已存在的项目目录生成 FIS 描述文件,其中包含项目的完整文件结构和内容。
  • 从 FIS 描述文件创建项目: 使用 FIS 描述文件来创建一个新的项目,包含所有的文件和文件夹结构。
  • 应用 FIS 描述文件中的变更: 读取 FIS 文件中的变更描述,并应用到现有的项目中,包括添加、修改和删除文件。

example

查看交互示例
[?] 请选择操作::
 > 进入项目交互模式
   从项目目录生成 FIS 描述文件
   从 FIS 描述文件创建项目
   从 FIS 描述文件应用项目变更
   退出应用

[?] 请输入项目根目录路径 (留空使用当前目录): D:\Projects\tarot
[?] FIS 描述文件 'tarot_prj_desc.fis' 已存在,是否覆盖? (Y/n):
[?] 请选择生成选项:(方向键选择;空格: 选择;回车: 确认):
   [ ] 添加 FIS 结构说明提示词 (中文)
   [X] 添加 FIS 结构说明提示词 (英文)
   [X] 使用 .gitignore 文件过滤项目文件
 > [X] 忽略 .fis 文件

正在生成 FIS 描述文件 'tarot_prj_desc.fis'...
项目描述已保存至: tarot_prj_desc.fis
项目初始化成功,进入对话交互模式。


>>> [Command]: 如你所见,这是一个空目录,请帮我在这个目录下编写一个 python 的交互式塔罗牌占卜游戏,通过与Gemini对话(从环境变量中获取api_key)来解释占卜结果,请 给出一个完整的项目结构

>>> [Gemini]: ```fis
{/*
This is a Python-based interactive tarot reading game that uses the Gemini API
for interpretation.

This project contains the following files:
- main.py: Main script for the game loop and user interaction.
- tarot.py:  Module containing tarot card data and interpretation logic.
- gemini_api.py: Module for interacting with the Gemini API.

This structure assumes you have your Gemini API key stored in an environment variable
named "GEMINI_API_KEY".
*/}

$$$ main.py
import random
from tarot import TarotDeck
from gemini_api import get_gemini_interpretation

def main():
    """Main function to run the interactive tarot reading game."""

    deck = TarotDeck()
    deck.shuffle()

    while True:
        input("Press Enter to draw a card, or type 'quit' to exit: ")
        if input == 'quit':
            break

        card = deck.draw_card()
        print(f"\nYou drew: {card.name}")

        if card.reversed:
            print("The card is reversed.")

        print("\nInterpretation:")
        interpretation = get_gemini_interpretation(card.name, card.reversed)
        print(interpretation)

if __name__ == "__main__":
    main()

$$$ tarot.py
class TarotCard:
    """Represents a single tarot card."""

    def __init__(self, name, meaning, reversed_meaning):
        self.name = name
        self.meaning = meaning
        self.reversed_meaning = reversed_meaning
        self.reversed = False

class TarotDeck:
    """Represents a deck of tarot cards."""

    def __init__(self):
        """Initializes a deck with Major Arcana cards."""

        self.cards = [
            TarotCard("The Fool", "New beginnings, innocence, spontaneity", "Recklessness, naivety, holding back"),
            TarotCard("The Magician", "Manifestation, power, action", "Manipulation, illusions, poor planning"),
            TarotCard("The High Priestess", "Intuition, subconscious, inner wisdom", "Secrets, hidden agendas, lack of clarity"),
            # ... Add the rest of the Major Arcana cards ...
        ]

    def shuffle(self):
        """Shuffles the deck of cards."""

        random.shuffle(self.cards)

    def draw_card(self):
        """Draws a random card from the deck."""

        card = random.choice(self.cards)
        card.reversed = random.choice([True, False])  # 50% chance of reversed
        return card

$$$ gemini_api.py
import os
import requests

def get_gemini_interpretation(card_name, reversed=False):
    """Gets a tarot card interpretation from the Gemini API."""

    api_key = os.environ.get("GEMINI_API_KEY")
    if not api_key:
        raise ValueError("GEMINI_API_KEY environment variable not set.")

    prompt = (
        f"Provide a concise and insightful interpretation for the tarot card '{card_name}' "
        f"{'in its reversed position' if reversed else ''}."
    )

    headers = {
        "Authorization": f"Bearer {api_key}",
        "Content-Type": "application/json",
    }
    data = {"prompt": prompt}

    response = requests.post("https://api.gemini.com/v1/generate", headers=headers, json=data)
    response.raise_for_status()  # Raise an exception for bad status codes

    interpretation = response.json()["choices"][0]["text"].strip()
    return interpretation

\```

>>> [Command]: /apply
正在应用最新 FIS 变更...
[?] 应用 FIS 变更将直接覆盖现有项目文件,请确保可以通过 git 等工具恢复项目文件,确定继续? (y/N): y

创建文件 main.py
创建文件 tarot.py
创建文件 gemini_api.py
[?] 是否更新 FIS 描述文件? (Y/n): y
项目描述已保存至: tarot_prj_desc.fis
FIS 描述文件 'tarot_prj_desc.fis' 更新成功。

>>> [Command]:

功能

  • 完全交互式终端: 直接使用 fis-tool 命令启动交互式终端,所有功能均可在交互式环境中使用。
  • 生成 FIS 描述文件: 根据项目目录生成包含所有文件和文件夹结构的 FIS 描述文件。(用于向 LLM 提供多文件项目信息)
  • 读取 FIS 描述文件: 解析 FIS 描述文件内容,还原文件结构和内容信息。(用于从 LLM 的回复还原多文件项目结构)
  • 应用 FIS 描述文件中的变更: 读取 FIS 描述文件中的变更描述,并应用到现有的项目中,包括添加、修改和删除文件。(用于应用 LLM 进行的变更)
  • 交互式项目操作: 在您的项目进行交互式对话,方便快速获取思路和更改方案,并快速将变更应用到项目中。(需要 Gemini API 密钥)

规划中

  • 支持连续对话
  • 支持更多文件过滤或摘要方式
  • 支持更多 Gemini 参数调整
  • 支持更多 LLM (需要 LLM 支持足够长的上下文,因为项目 FIS 文件包含了大量文件内容信息)

使用方法

快速开始

# 1. 通过 pip 安装
pip install fis-tool --upgrade

# 2. 启动交互式终端,根据指引选择功能
fis-tool

交互式项目操作

FIS 工具提供了交互式项目操作模式,您可以通过对话的方式与工具进行交互,首先你需要获取一个 Gemini API 密钥。

  1. 进入交互模式: 直接使用 fis-tool 命令选择 "进入项目交互模式" 选项。
  2. 初始化项目: 根据 FIS 工具指引完成项目初始化,生成 FIS 文件。
  3. 对话交互: 输入您的指令,FIS 工具会根据 FIS 文件和您的指令与 Gemini 进行交互,并返回结果。
  4. 应用变更: FIS 工具会自动将对话中的变更应用到项目中,方便您快速调整和迭代。

命令行操作

  1. 生成 FIS 描述文件:
    • 使用 fis-tool generate 命令生成 FIS 描述文件。
    • 使用 -o--output 参数指定输出文件路径。
    • 使用 -e--explanation 参数选择添加 FIS 结构说明提示词(可选,默认不添加)。
    • 使用 -g--gitignore 参数使用 .gitignore 文件忽略项目文件(可选,默认不使用)。
  2. 从 FIS 描述文件创建项目:
    • 使用 fis-tool create 命令从 FIS 描述文件创建项目。
    • 使用 -f--file 参数指定 FIS 描述文件路径。
    • 使用 -o--output 参数指定输出项目路径。
  3. 应用 FIS 描述文件中的变更:
    • 使用 fis-tool apply 命令将 FIS 描述文件中的变更应用到项目。
    • 使用 -p--project 参数指定项目根目录路径。
    • 使用 -f--file 参数指定 FIS 描述文件路径。

命令示例

# 生成 FIS 描述文件
fis-tool generate -p my_project -o my_project.fis -e zh -g

# 从 FIS 描述文件创建项目
fis-tool create -f my_project.fis -o new_project

# 应用 FIS 描述文件中的变更
fis-tool apply -p my_project -f changes.fis

注意事项

  1. Gemini 代理问题

由于 Gemini 官方库没有提供设置代理的功能,如果需要使用代理访问,需要手动修改官方库代码

修改文件位置: (你的运行 Python 环境)\Lib\site-packages\google\ai\generativelanguage_v1beta\services\generative_service\transports\grpc.py (117 行)

options=[
   ("grpc.max_send_message_length", -1),
   ("grpc.max_receive_message_length", -1),
   ("grpc.http_proxy", "http://127.0.0.1:7890"),   # 增加这一行,按需要设置为你的代理地址
],