File size: 4,006 Bytes
08bc52f a4a35d8 c015fd4 a4a35d8 197f492 bdf7057 197f492 c33b262 a4a35d8 197f492 7faa9af bdf7057 a4a35d8 197f492 08bc52f 197f492 e9dba00 197f492 8840474 197f492 d562426 197f492 9754a84 197f492 9754a84 a4a35d8 bdf7057 8688e31 a4a35d8 bdf7057 a4a35d8 bdf7057 a4a35d8 bdf7057 197f492 05d53db d686cc9 a4a35d8 d686cc9 a4a35d8 197f492 7faa9af a4a35d8 bdf7057 a4a35d8 c33b262 7faa9af 197f492 a4a35d8 80c38e5 c90742c 80c38e5 c90742c 78ab3ee 80c38e5 7faa9af 8189ef8 a4a35d8 7faa9af 0bf7d6b a4a35d8 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 |
"""Talk to spaces VM via subprocess.check_output."""
# pylint: disable=wrong-import-position
import sys
from pathlib import Path
if "." not in sys.path:
sys.path.insert(0, ".")
# import httpx
import subprocess as sp
from shlex import split
import pandas as pd
import matplotlib
import matplotlib.pyplot as plt
import seaborn as sns
# from textwrap import dedent
from inspect import cleandoc
import gradio as gr
import logzero
from logzero import logger
from gradiobee.seg_text import seg_text
matplotlib.use("Agg") # non-interactive for plt.savefig
sns.set()
sns.set_style("darkgrid")
logzero.loglevel() # default to 10
# def greet(command):
def process(command):
"""Probe vm."""
# single line: command
# logger.info("input:\n\t %s", command)
# print("print input:\n\t %s" % command)
# print("print input*:\n\t %s" % "*".join(command.splitlines()))
logger.info("input: %s", command)
is_command = True
is_command = command.strip().splitlines().__len__() < 2 and len(command.strip()) < 500
if is_command:
try:
# out = sp.check_output(split(command), encoding="utf8", stderr=STDOUT)
proc = sp.Popen(
split(command), encoding="utf8", stdout=-1, stderr=-1
) # sp.PIPE: -1
out, err = proc.communicate()
# success = True
return f"[{out}]", f"[{err}]"
except Exception as e:
out, err = "", str(e)
# success = False
return f"[{out}]", f"[{err}]"
# quick test altair altair-save tooltip
# from PIL import Image
# import altair as alt
# from altair_saver import save
# alt.renderers.enable('altair_saver', fmts=['vega-lite', 'png'])
df_ = pd.DataFrame(data={'x': [1, 2], 'y': [3, 4], "cos": [0.1, 0.5]})
# chart_df = alt.Chart(df_).mark_circle(size=60).encode(
# x='x',
# y='y',
# color='cos',
# tooltip=['x', 'y', 'cos', ]
# )
# .interactive()
# save(chart_df, "chart_df.html")
# chart_df_html = Path("chart_df.html").read_text("utf")
# save(chart_df, "chart_df.png")
# chart_df_png = Path("chart_df.png").read_bytes()
# chart_df_png = Image.open("chart_df.png")
# chart_df_png = "chart_df.png"
# scatter_plot.save('simple_scatter_plot_with_altairchart.html')
# chart_df.save("chart_df.html") # does not work, constains js
# chart_df_html = Path("chart_df.html").read_text("utf")
# chart_df.save("chart_df.png") #
# chart_df_png = "chart_df.png"
# not is_command or not flag: text, do seg_text
_ = "\n\n".join(seg_text(command.strip()))
logger.debug(_)
# logger.debug(chart_df_html)
# print(_)
# print(chart_df_html)
# _ = seg_text(command.strip())
_ = cleandoc(
f"""seg_text output (segmented sents):
{_}
"""
).strip()
# return _, chart_df_html
plt.figure()
sns.scatterplot(data=df_, x='x', y='y')
Path("img").mkdir(exist_ok=True)
plt.savefig("img/df.png")
plt.close()
df_png = "img/df.png"
# return _, chart_df_png
return _, df_png
iface = gr.Interface(
# fn=greet,
# inputs="text",
fn=process,
# inputs="text",
inputs=gr.inputs.Textbox(
lines=5,
placeholder="Type or paste input here then click 'Submit'",
default="python -m site",
label="command or multiline text",
),
# outputs="text",
# outputs=["text",],
# outputs=["text", "html"],
outputs=[
"text",
gr.outputs.Image("auto"),
],
examples=[
"cat /proc/version",
"free # show free memory",
"uname -m",
"df -h .",
"cat /proc/cpuinfo",
"""python -c "from psutil import virtual_memory; print(virtual_memory())" """,
],
title="probe the system",
description="Talk to the system via subprocess.check_output ",
layout="vertical",
)
iface.launch(share=True, debug=True)
# iface.launch()
|