场景:
针对个人的最近的一个日常使用场景的一个需求。启动特定的程序,需要输入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 {your-ak-key} -sk {your-sk-key}" -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在代码应用上的表现堪称卓越。它不仅具备强大的代码生成能力,还能提供智能化的编程支持。这使得它成为了我们编程路上的得力助手,为我们带来了前所未有的编程体验。