Skip to main content

FIS (File Interaction Script) 工具,用于生成、读取和应用项目文件结构描述,方便与 LLM 进行交互,实现高效的代码变更。

Project description

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 密钥)
  • 自定义过滤规则: 提供一套独立的自定义规则配置,支持与 .gitignore 共同使用来有效过滤项目文件,提高交互效率。
  • 多对话模型支持: 目前已支持 Gemini 和 OpenAI 及各种与 OpenAI 接口兼容的模型。

规划中

  • 支持连续对话
  • 支持更多 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

常见问题 Q/A

Q: 如何设置 Gemini 代理?

A: 由于 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"),   # 增加这一行,按需要设置为你的代理地址
],

[2024.6.14] 更新: 尝试 patch 官方库注入代理配置,可以先尝试使用交互操作输入代理地址,如果不行再修改官方库代码

Q: 为什么我在交互操作中选择了将 KEY 等信息保存到环境变量,下次运行时仍然需要我填写?

A: 请重启你的终端,环境变量才会生效。

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fis_tool-0.4.0.tar.gz (24.1 kB view details)

Uploaded Source

Built Distribution

fis_tool-0.4.0-py3-none-any.whl (26.2 kB view details)

Uploaded Python 3

File details

Details for the file fis_tool-0.4.0.tar.gz.

File metadata

  • Download URL: fis_tool-0.4.0.tar.gz
  • Upload date:
  • Size: 24.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.8.18 Linux/6.5.0-1021-azure

File hashes

Hashes for fis_tool-0.4.0.tar.gz
Algorithm Hash digest
SHA256 6c883ff9b158e27d30ee5de09a268de86c59ace232572171852e5ab942bb0bc7
MD5 e9b63e8f54e8d19b25e4715dabe693e0
BLAKE2b-256 7ba6ea0fd7028c4e462bd64780f737df67922c91371f3cc9efcea5d38c60ab01

See more details on using hashes here.

File details

Details for the file fis_tool-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: fis_tool-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 26.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.8.18 Linux/6.5.0-1021-azure

File hashes

Hashes for fis_tool-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 79cd23c4a524ed882d74f78583cdd45dfffc8f7dd9fe9cfd3914ade82b4c08ed
MD5 d042f785e8946e235a0a5bba7f0c1bd4
BLAKE2b-256 40a527ff6e15bbf8c12ef0d19773a77229b51b2a3e63cbc4fcb62eadf459c7cf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page