HTML and Python Coding With ChatGPT Vision (Chatbot Battle GUI)
π» Themes: AI
π€ Chatbots: ChatGPT
βοΈ Prompt engineering: Coding, Image Analysis
[Related – Is Philosophy a Science? Introducing SCBN Chatbot Battles ] [GitHub repository]
Tabulating and Formatting Text in HTML

π Suggest a simple HTML table format where I can include this information in a tabulated way, eliminating the hashtags of the social media post, and pulling the links in text (so the URLs are not shown). The table should be titled “Chatbot Battle: Is Philosophy a Science?“. I want to keep the emojis for the scoring system (i.e. π€πΉοΈπΉοΈ), but the ranking represented by the emoji medals can now be represented in a more formal way (such as winner, challenger, laggard… be creative with that)
π€ [Preliminary code. Final version available on GitHub]
This is a simple HTML structure for the provided information, and it presents the chatbots’ performance in a tabulated manner. The emojis are retained for scoring, and the rankings are represented with descriptive titles such as “Winner,” “Runner-up,” and “Contender”.
π Can we make the font Josefin Sans and use a color palette similar to the one in the attached screen capture? For example, we could use #c9c1f2 for headings background, and the links can be #c171f4

π€ A screenshot of the reddgr.com website showcasing a clean and organized layout. The main content area displays a blog post prompt with an associated date and tags. A sidebar on the right lists a variety of other blog topics. The color scheme is primarily soft purples and whites.
π€ … Got it. Here’s the modified HTML code with the “Josefin Sans” font and the specified color palette:
[Preliminary code. Final version available on GitHub]
[routine iterations and error fixing]
π I will make two more minor modifications. I think it’s good to add an emoji medal after the winner, runner-up, contender (gold, silver, bronze… looks cool). Also, I’m calling the ranking SCBN, so instead of “Rank”, the column heading would be Rank (SCBN)
π€ Absolutely! Here’s your updated code:
[Preliminary code. Final version available on GitHub]
π Would this HTML chart look good on a mobile device? Do you have any suggestions if I want to make it mobile-friendly? [preliminary code]
π€ To ensure the HTML chart is mobile-friendly, consider the following suggestions:
- Responsive Font Size: Use relative units like em,rem, or viewport units (vw,vh) instead of fixedpxfor font sizes. This will make the text scale according to device size.
- Table Overflow: On smaller screens, tables might overflow. You can wrap the table within a divwithoverflow-x: auto;, so users can scroll horizontally if needed.
- Reduce Padding for Mobile: Reduce padding and margins on smaller screens to utilize the screen space more efficiently.
- Break Words: If any table cell content is too long and doesn’t fit, use word-wrap: break-word;to prevent overflow.
- Use Media Queries: Media queries allow you to apply styles based on the device characteristics, especially its width.
Here’s a modified version incorporating these suggestions:
[Preliminary code. Final version available on GitHub]
π [iterations]
π€ …Here’s the modified code:

Graphical User Interface Design with Tkinter
π Now I would like to design a simple user interface where I would enter the main elements of the table (chatbot, links, and a score of 0 to 3 for each parameter). The UI script would calculate the rank based on my scores, convert the scores into the visual emoji form with π€ and πΉοΈ, and build the whole HTML code. That would obviously require more than just HTML and more than just WordPress. I don’t care too much about which type of application to use for the user interface, it can be anything I can easily run on my Windows computer (I could convert it into a website functionality in the future, but not yet). For handling the code you write, I would be comfortable using Python
π€ Understood! Let’s create a simple Python application with a graphical user interface (GUI) for this task. We’ll use the Tkinter library which is bundled with most standard Python installations.
The basic idea is:
- Create input fields for Chatbot name, link, and scores.
- Calculate the rank based on scores.
- Convert scores to emojis.
- Generate the HTML code.
Here’s a basic prototype of the application:

[preliminary code. Final version available on GitHub]
Instructions:
- Ensure you have Python installed on your Windows machine.
- Copy and paste the above code into a Python file, say chatbot_ranking_app.py.
- Run the script: python chatbot_ranking_app.py.
The script will launch a simple GUI where you can enter chatbot details and scores. When you press the “Generate HTML” button, the appropriate HTML will be displayed in a text box below. You can then copy this HTML and use it in your table.
Note: The ranking is marked as “TBD” (To Be Determined) for now, as calculating ranks might require additional logic based on all chatbot scores.

π This looks promising. The next step is to update the Python code so that, when I hit the “Generate HTML” button, the whole HTML code is generated including all correctly sorted and filled table rows (chatbots). Below is the original HTML you created for three rows:
π€ Sure! I’ll modify the generate_html method to include the CSS styles, the header, and the table structure in the generated HTML. Additionally, the chatbots will be inserted into the table rows based on their rankings. Here’s the updated code:
[More iterations oncode]
π This looks very good. There are a few more details I either forgot to define or are better to add now that we are near completing the work:
1. We should also add a text box to customize the title of the HTML. The HTML title will always have the format “Chatbot Battle: …”, and the space will be filled with what the user enters as “Chatbot Battle Title” in the UI. This text box can be above all others, noticing it shouldn’t be wiped out when we click on “Add Chatbot”.
2. When there is a tie of two or more chatbots with the same score, the same medal title should be awarded to all of them. For example, if the maximum score is 12 and three chatbots have the same score, all three would get the “π₯ Winner” tag. If two chatbots are tied at the third place, the two of them would get π₯ Contender…
3. Finally, it would be convenient to have one button for copying the HTML code to the clipboard, and another to clear the screen.
π€ Sure, I’ll make those enhancements […]

[More iterations and fixes. Final version available on GitHub]
π This looks great. Thank you. Hopefully we can evolve it in the future. Question: could we also easily add a function that converts the HTML code into a PNG image, including a watermark with my website name?
π€ Yes, converting the generated HTML into a PNG image is feasible using Python, but the process involves a few steps:
- Render HTML to an image: You can use a library called Selenium to open the HTML in a web browser and take a screenshot.
- Add a watermark: Once you have the image, you can use the PIL(orPillow) library to overlay a watermark.
Here’s a rough approach:

βοΈ The code for rendering the HTML into an image is not yet developed, but I will be adding code to the GitHub repository as more functionalities are added, always with guidance from a chatbot. See below an Illustrative SCBN Chatbot Battle chart with the current functionality. Scores and chatbots are provisional, the topic is being worked on:
Chatbot Battle: Reality is what lies beneath our beliefs when we stop believing
| Chatbot | Rank (SCBN) | Specificity | Coherency | Brevity | Novelty | Link | 
|---|---|---|---|---|---|---|
| Reddgr Chat | π₯ Winner | π€π€π€ | π€π€π€ | π€π€π€ | π€π€π€ | View Chat | 
| TalkingToChatBots.com | π₯ Winner | π€π€π€ | π€π€π€ | π€π€π€ | π€π€π€ | View Chat | 
| πChat (Alpaca) | π₯ Runner-up | π€π€π€ | π€π€π€ | π€π€πΉοΈ | π€π€πΉοΈ | View Chat | 
| Bardo | π₯ Contender | π€π€π€ | π€π€πΉοΈ | π€π€πΉοΈ | π€π€πΉοΈ | View Chat | 
| ChatCCCP | π€π€πΉοΈ | π€π€πΉοΈ | π€π€πΉοΈ | π€π€πΉοΈ | View Chat | |
| Claudius | π€π€π€ | π€πΉοΈπΉοΈ | πΉοΈπΉοΈπΉοΈ | π€π€π€ | View Chat | |
| Casper | π€π€πΉοΈ | π€π€πΉοΈ | πΉοΈπΉοΈπΉοΈ | π€π€π€ | View Chat | 

 
		
Leave a Reply