场景:
针对个人的最近的一个日常使用场景的一个需求。启动特定的程序,需要输入ak_key,sk_key。每次启动都要输入,就很麻烦。我希望有一个简化调用这个程序的东西。自动帮我输ak_key,sk_key简化我的使用成本。
于是,我寄希望于通过文心一言4.0的代码能力帮我实现这一能力。减少我的使用成本。好戏开始了!
利用4.0帮我完成这个能力的详细过程。也是为了证明文心一言4.0的实力!
个人prompt:
您是一名win系统资深专家,你对该系统的各种使用完完全全了解。我想写一个Windows系统下的脚本,功能如下:
功能1,启动脚本时,创建一个窗口,其中有两个输入框(第一个填ak key,第一个填sk key)和一个确定按钮。
功能2:,点击确定后,判断输入框,输入框存在数据的情况下,将数据分别填入以下三引号中的示例脚本代码
"""
@echo off
start cmd /k "cd /d C:\Users\Administrator\Desktop\baidu\chat-pro\functions_windows_amd64 && functions -ak 456456sfsfs -sk fs1351as531g63" -port 8091
"""
文心4.0回复:
要创建一个带有输入框和按钮的图形用户界面(GUI)并在点击按钮后执行特定的命令,您需要使用一种支持GUI编程的脚本语言,比如PowerShell、Python(使用Tkinter、PyQt等库)或者C#(使用Windows Forms或WPF)。批处理脚本(Batch)本身不支持创建GUI。
以下是一个使用Python和Tkinter库实现您所需功能的简单示例。请确保您已经安装了Python,并且Tkinter库也已经可用(它通常与Python一起安装)。
import tkinter as tk
from tkinter import messagebox
import subprocess
def run_command():
ak_key = ak_entry.get()
sk_key = sk_entry.get()
if ak_key and sk_key:
# 构建要在新的CMD窗口中执行的命令字符串
command = f'cd /d C:\\Users\\Administrator\\Desktop\\baidu\\chat-pro\\functions_windows_amd64 && functions -ak {ak_key} -sk {sk_key} -port 8091'
# 使用subprocess启动一个新的CMD窗口并执行命令
try:
# 注意:这里使用start命令打开一个新的CMD窗口,并通过/c参数执行命令
subprocess.run(f'start cmd /c "{command}"', shell=True, check=True)
messagebox.showinfo("Success", "Command Executed Successfully!")
except subprocess.CalledProcessError as e:
messagebox.showerror("Error", f"Command Execution Failed: {e}")
else:
messagebox.showerror("Error", "Please fill in both AK and SK keys.")
# 创建主窗口并设置大小
root = tk.Tk()
root.title("AK/SK Key Input")
root.geometry("400x200") # 设置窗口宽为400像素,高为200像素
# 创建标签和输入框
ak_label = tk.Label(root, text="AK Key:")
ak_label.pack(pady=10) # 添加一些垂直填充
ak_entry = tk.Entry(root)
ak_entry.pack()
sk_label = tk.Label(root, text="SK Key:")
sk_label.pack(pady=10) # 添加一些垂直填充
sk_entry = tk.Entry(root)
sk_entry.pack()
# 创建确定按钮
submit_button = tk.Button(root, text="确定", command=run_command)
submit_button.pack(pady=20) # 添加一些垂直填充
# 运行主循环
root.mainloop()
将上述代码保存为.py
文件,比如ak_sk_input.py
,然后运行它。这将创建一个窗口,您可以在其中输入AK和SK密钥,然后点击确定按钮来执行命令。请确保将路径和命令修改为您的实际路径和命令。
其实按照上面的python代码,经过个人测试,以上代码就可以完美运行,且符合我的使用需求了,很丝滑。
但是个人要求较高,我觉得页面还不够好看整洁,功能还可以更丰富完善,更方便用户使用。于是我决定继续用文心一言4.0帮我调整,增加新的功能,并将页面修饰好看一点。直接上干货演示:
个人prompt:
增加新的功能:
你是一名python代码助手,使用上面的代码已经正常跑通了!非常棒!接下来,我希望基于以上代码,不改变原有功能,增加新的功能,我希望作为单独的功能函数。实现功能如下:
"""
1,当我启动python脚本,打开页面的时候,我希望在初始页面增加一个选择路径目录文件的选项。
2,当我选择好目录文件之后,读取当前路径下以及当前路径目录下的,所有.exe文件(只读取当前路径的1,2级目录的.exe文件,不过多读取,避免读取异常),将读取到的.exe文件展示在初始页面。
3,当我选择好展示在初始页面的.exe文件列表中的其中一项时,将这个选中的.exe文件路径填入原有的win脚本代码中
"""
将整体页面的布局进行修饰,保持美观:
请您按照以下要求进行优化。优化要求如下:
1,ak/sk输入框长度稍微长一点,输入框对应的提示要和输入框平行(如:ak_label = tk.Label(root, text="AK Key:") )。
2,将路径浏览按钮,进行居中,并放到输入框的下面一些(Browse...)。
3,将exe文件列表放到路径浏览按钮下面,并居中(如下相关:exe_label = tk.Label(root, text="Select EXE Directory:") )。
4,将列表中的exe文件进行别名显示,但不能影响路径的正确选中。如原列表所示:
"""
1,C:/Users/Administrator/Desktop/baidu/chat-pro\chat-demo_windows_amd64\chat-demo.exe。
2,C:/Users/Administrator/Desktop/baidu/chat-pro\chat-faq_windows_amd64\chat-faq.exe
"""。
调整列表如以下所示:
"""
1,chat-demo。
2,chat-faq。
"""
经过上述prompt对代码的两次调整,激动人心的时刻到了,亲测可用,完美符合我个人使用基本要求了。完整代码如下:
import tkinter as tk
from tkinter import filedialog, Listbox, messagebox
import os
import subprocess
# 写上个人ak_key Sk_Key,这里作为初始值
Ak_Key = "your_ak_key"
Sk_Key = "your_sk_key"
Port = 8091
# 用于运行exe文件并附带所提供的AK、SK密钥的函数
def run_command(selected_exe):
global Port
# 对port进行自增
Port +=1
# 获取AK和SK密钥
ak_key = ak_entry.get()
sk_key = sk_entry.get()
# AK、SK密钥和选中的exe文件都必需
if ak_key and sk_key and selected_exe:
# 构建启动命令
command = f'cd /d "{os.path.dirname(selected_exe)}" && start "" "{os.path.basename(selected_exe)}" -ak {ak_key} -sk {sk_key} -port {Port}'
try:
# 执行命令
subprocess.Popen(command, shell=True)
# messagebox.showinfo("成功", "Command Executed successfully!")
except Exception as e:
# 如果命令失败,显示错误信息
messagebox.showerror("异常", f"Command Execution Failed: {e}")
else:
if not ak_key or not sk_key:
messagebox.showerror("异常", "Please fill in both AK and SK keys.")
if not selected_exe:
messagebox.showerror("异常", "Please select an .exe file.")
# 全局变量用于存储exe文件路径与别名的映射 --------------------
exe_files_map = {}
def browse_folder():
folder_path = filedialog.askdirectory()
if folder_path:
global exe_files_map
exe_files_map.clear() # 清除旧的映射
exe_files = find_exe_files(folder_path)
exe_listbox.delete(0, tk.END)
for exe_file in exe_files:
filename = os.path.basename(exe_file) # 仅文件名
alias = filename.replace('.exe', '')
exe_listbox.insert(tk.END, alias) # 只插入别名
exe_files_map[alias] = exe_file # 存储别名到完整路径的映射
def find_exe_files(folder_path):
exe_files = []
for root, dirs, files in os.walk(folder_path):
level = root.replace(folder_path, '').count(os.sep)
if level <= 3:
for file in files:
if file.lower().endswith('.exe'):
exe_files.append(os.path.join(root, file))
else:
break # 只进入选定文件夹下的3级子文件夹
return exe_files
def on_exe_select(event):
selected_alias = event.widget.curselection()
if selected_alias:
alias = event.widget.get(selected_alias)
selected_exe_path = exe_files_map.get(alias) # 从映射中检索完整路径
if selected_exe_path:
exe_entry.delete(0, tk.END)
exe_entry.insert(0, selected_exe_path)
# 创建主窗口
root = tk.Tk()
root.title("AK/SK Key Input with EXE Selector")
root.geometry("550x450") # Adjusted window size to fit new content better
# 创建AK/SK输入框
ak_label = tk.Label(root, text="AK Key:")
ak_label.grid(row=0, column=0, sticky='w', pady=10, padx=10) # Anchor to the west (left)
ak_entry = tk.Entry(root, width=50) # Increased width
ak_entry.grid(row=0, column=1, columnspan=2, sticky='ew', pady=5, padx=60)
ak_entry.insert(0, Ak_Key) # 初始化AK
sk_label = tk.Label(root, text="SK Key:")
sk_label.grid(row=1, column=0, sticky='w', pady=10, padx=10) # Anchor to the west (left)
sk_entry = tk.Entry(root, width=50) # Increased width
sk_entry.grid(row=1, column=1, columnspan=2, sticky='ew', pady=5, padx=60)
sk_entry.insert(0, Sk_Key) # 初始化AK Key为1
# 创建用于选择exe文件的部分
exe_frame = tk.Frame(root)
exe_frame.grid(row=2, column=0, columnspan=3, pady=5, sticky='ew')
exe_button = tk.Button(exe_frame, text="浏览...", command=browse_folder)
exe_button.grid(row=0, column=0, sticky='w', pady=10, padx=10)
exe_entry = tk.Entry(exe_frame, width=50)
exe_entry.grid(row=0, column=1, sticky='ew',padx=60)
exe_label = tk.Label(root, text="列表:")
exe_label.grid(row=3, column=0, sticky='w', pady=10, padx=10)
# 创建exe文件列表
exe_listbox_frame = tk.Frame(root)
exe_listbox_frame.grid(row=4, column=0, columnspan=3, pady=0, padx=10, sticky='ew')
exe_listbox = tk.Listbox(exe_listbox_frame, width=70, height=10) # Increased width for aliases
exe_listbox.grid(row=0, column=0, sticky='ewns')
exe_listbox.bind('<<ListboxSelect>>', on_exe_select)
# 创建运行命令按钮
run_button_frame = tk.Frame(root)
run_button_frame.grid(row=5, column=0, columnspan=3, pady=10, sticky='ew')
run_button = tk.Button(run_button_frame, text="确定", width=10, command=lambda: run_command(exe_entry.get()))
run_button.grid(row=0, column=0, columnspan=2, padx=220)
# 运行主循环,显示GUI
root.mainloop()
接下来测试 我们的测试python程序,在程序文件当前目录下,打开cmd窗口,执行命令如下:
py test1.py
启动成功如图所示:
当我输入 ak_key, sk_key, 选中第一个路径的程序,点击确认,完美启动,如下图所示:
为了进一步减少使用成本,让不懂代码的用户也能点击使用,且有交互界面,写了一个win脚本,也是一个选择:win脚本,进一步减轻小白用户的使用成本。
总结:
在数字化时代,代码已成为驱动世界的重要力量。而在这个领域中,文心一言4.0以其出色的代码应用能力,为我们展现了一个全新的编程世界。
从第一次的prompt引导中,我们就已经见证了文心一言4.0的强大实力。它不仅能够迅速理解我们的代码需求,更能以高效、准确的方式生成所需的代码片段。这种能力在后续的多次prompt引导中得到了进一步的体现,无论是新增功能还是优化现有代码,文心一言4.0都能一次过,无需反复调试和修改。
这种卓越的代码应用能力,使得文心一言4.0成为了国产AI大模型中的佼佼者。正如百度老板李彦宏所言,未来人人都是程序员。而文心一言4.0正是实现这一愿景的重要工具。通过简单的自然语言引导,它就能将我们的想法和需求转化为实际的代码,大大提高了编程效率,减轻了程序员的工作负担。
值得一提的是,文心一言4.0并不仅仅是一个代码生成工具。它更是一个智能的编程助手,能够在我们的编程过程中提供有价值的建议和帮助。这种智能化的编程体验,让我们能够更加专注于创新和解决问题,而不用担心繁琐的编码工作。
总的来说,文心一言4.0在代码应用上的表现堪称卓越。它不仅具备强大的代码生成能力,还能提供智能化的编程支持。这使得它成为了我们编程路上的得力助手,为我们带来了前所未有的编程体验。