{
  "query": "How do you create tables or graphs with coding?",
  "query-id": 67,
  "gold_response": "Creating Tables and Graphs with Python (Pandas + Matplotlib)\n\nStep 0. Install once in a terminal\n\n```\npip install pandas matplotlib openpyxl  # openpyxl enables Excel read and write\n```\n\nStep 1. Import in your Python file or notebook\n\n```\nimport pandas as pd\nimport matplotlib.pyplot as plt\n```\n\nTask 1. Create and display tables (DataFrame)\n\n```\n# Minimal sample data\ndata = {\n    'Month': ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun'],\n    'Sales': [100, 120, 150, 130, 170, 180],\n    'Cost':  [60,  65,   90,  85, 100, 110]\n}\n\n# Create a table\ndf = pd.DataFrame(data).set_index('Month')  # use Month as the index (row labels)\n\n# Check the table quickly\nprint(df.head())          # first 5 rows\n# or display the whole table\nprint(df)\n```\n\nTask 2. Draw line, bar, and pie charts\n\n2.1 Line chart (trend over time)\n```\nax = df['Sales'].plot(\n    kind='line', title='Monthly Sales', marker='o', figsize=(8, 4)\n)\nax.set_xlabel('Month')\nax.set_ylabel('Sales')\nax.grid(True)\nplt.show()\n```\n\n2.2 Bar chart (compare categories or multiple series)\n```\nax = df[['Sales', 'Cost']].plot(\n    kind='bar', title='Sales vs Cost by Month', figsize=(8, 4)\n)\nax.set_xlabel('Month')\nax.set_ylabel('Amount')\nplt.xticks(rotation=0)\nplt.legend(title='Metric')\nplt.show()\n```\n\n2.3 Pie chart (parts of a whole)\n```\n# Example category data\ncat_df = pd.DataFrame({'Revenue': [350, 400, 250]},\n                      index=['Electronics', 'Clothing', 'Food'])\n\nax = cat_df['Revenue'].plot(\n    kind='pie', title='Revenue Share by Category', autopct='%.1f%%', figsize=(5, 5)\n)\nplt.ylabel('')  # remove y label for a cleaner pie\nplt.show()\n```\n\nTask 3. Visualize CSV or Excel files (and save results)\n\n3.1 Read a CSV and plot\n```\nsales_csv = pd.read_csv('sales.csv')  # add encoding='utf-8' or 'euc-kr' if needed\nprint(sales_csv.head())\n\n# Example: line chart if file has Month and Sales columns\nax = sales_csv.plot(x='Month', y='Sales', kind='line', marker='o', title='Sales from CSV')\nax.set_xlabel('Month')\nax.set_ylabel('Sales')\nplt.show()\n```\n\n3.2 Read an Excel file and plot\n```\nsales_xlsx = pd.read_excel('sales.xlsx', sheet_name='Sheet1')  # requires openpyxl\nprint(sales_xlsx.head())\n\n# Example: bar chart if file has Region and Revenue columns\nax = sales_xlsx.plot(x='Region', y='Revenue', kind='bar', title='Revenue by Region (Excel)', legend=False)\nax.set_xlabel('Region')\nax.set_ylabel('Revenue')\nplt.xticks(rotation=0)\nplt.show()\n```\n\n3.3 Save tables to CSV or Excel\n```\n# Save the DataFrame created earlier\ndf.to_csv('summary.csv', index=True, encoding='utf-8-sig')  # utf-8-sig works well with Excel\n\ndf.to_excel('summary.xlsx', index=True)  # write an xlsx file (openpyxl used under the hood)\n```\n\nOptional tips\n- If text labels look garbled, specify encoding when reading CSV: pd.read_csv('file.csv', encoding='utf-8') or encoding='euc-kr'.\n- To display non-Latin characters in plots:\n```\nimport matplotlib as mpl\n# Windows\nfont_path = 'C:/Windows/Fonts/malgun.ttf'\nfont_name = mpl.font_manager.FontProperties(fname=font_path).get_name()\nmpl.rc('font', family=font_name)\n# Mac (uncomment if needed)\n# mpl.rc('font', family='AppleGothic')\n```\n\nQuick reference\n- Create table: pd.DataFrame(dict). Display: df.head(), print(df)\n- Plot types: kind='line' or 'bar' or 'pie'\n- Labels and title: ax.set_xlabel, ax.set_ylabel, title parameter in plot\n- Show the figure: plt.show()\n- File I O: pd.read_csv, pd.read_excel, df.to_csv, df.to_excel",
  "gold_information": [
    "You can create tables and graphs using a programming language with a data-analysis library and a plotting library.",
    "Install the required packages using a package manager before running the code.",
    "Import the data-analysis module and the plotting module at the start of the script.",
    "Build a table from dictionary data and set a column as the row index.",
    "Preview the table by printing it or showing the first few rows.",
    "Create a line chart to show trends over time with markers, grid, title, and axis labels.",
    "Create a bar chart to compare categories or multiple series with a legend and adjusted tick rotation.",
    "Create a pie chart to display parts of a whole with percentage labels and a clean layout.",
    "Read a comma-separated file into a table and plot selected columns by specifying x and y fields.",
    "Read a spreadsheet file from a named sheet and plot a category against a value.",
    "Save tables to comma-separated files or spreadsheet files with an optional index.",
    "Specify file encoding when reading text data to prevent garbled characters.",
    "Configure a font family with a system font path to render non-Latin characters in plots.",
    "Use plot parameters such as kind, title, axis labels, legend, and figure size to customize visuals.",
    "Display figures with a show command after configuring the axes.",
    "Reading or writing spreadsheet files may require an additional engine library."
  ]
}