前言:
目前兄弟们对“python颜色转换”大概比较注重,姐妹们都想要分析一些“python颜色转换”的相关文章。那么小编也在网上搜集了一些有关“python颜色转换””的相关资讯,希望朋友们能喜欢,咱们一起来学习一下吧!无需了解任何Web框架即可轻松地将您的数据科学项目转换为出色的应用程序
如果我们没有很好的方法来展示机器学习项目,那么它永远不会真正完成。
过去,经过精心制作的可视化效果图或小型PPT足以展示数据科学项目,而随着RShiny和Dash等仪表板工具的出现,优秀的数据科学家需要对Web有一定的了解相处的框架。
Web框架很难学习。我仍然对所有的HTML,CSS和Javascript以及所有的点击和试用感到困惑,因为它们看起来很简单。
更不用说做同一件事的许多方法,这使我们对数据开发人员感到困惑,而Web开发是他们的第二技能。
那么,我们注定要学习网络框架吗?还是在半夜打电话给我们的开发人员朋友,以解决愚蠢的疑问?
这是StreamLit出现的地方,它兑现了仅使用Python创建Web应用程序的承诺。
Python之禅:简单胜于复杂,Streamlit使创建应用变得非常简单。
安装
安装就像运行命令一样简单:
pip install streamlit
要查看我们的安装是否成功,我们可以运行:
streamlit hello
这应该显示一个屏幕,显示:
您可以转到本地URL:localhost:8501在浏览器中,查看Streamlit应用程序的运行情况。开发人员提供了一些不错的演示,您可以使用它们。在返回之前,请花点时间并感觉一下工具的功能。
Streamlit Hello World
Streamlit旨在使用简单的Python简化应用程序开发。
因此,让我们编写一个简单的应用程序,看看它是否能够兑现承诺。
在这里,我从一个简单的应用程序开始,我们将其称为streamlit的Hello World。只需将下面给出的代码粘贴到一个名为helloworld.py
import streamlit as stx = st.slider('x')st.write(x, 'squared is', x * x)
并且,在终端上运行:
streamlit run helloworld.py
瞧,您应该能够在浏览器中看到一个运行中的简单应用,该应用localhost:8501可让您移动滑块并给出结果。
一个简单的滑块小部件应用
这很容易。在上面的应用程序中,我们使用了Streamlit的两个功能:
st.slider我们可以滑动以更改Web应用程序输出的小部件。以及通用st.write命令。我惊讶于它如何能够从图表,数据框和简单文本中编写任何内容。稍后对此进行更多讨论。
重要提示:请记住,每次更改窗口小部件的值时,整个应用程序都会从上到下运行。
Streamlit Widgets(小部件)
小部件为我们提供了一种控制应用程序的方式。了解这些小部件的最佳位置是API参考文档本身,但我将介绍一些最终可能会用到的最突出的小部件。
1.滑块
streamlit.slider(label, min_value=None, max_value=None, value=None, step=None, format=None)
我们已经st.slider在上面看到了实际操作。它可以与min_value,max_value和step一起使用,以获取一定范围内的输入。
2.文字输入
获取用户输入的最简单方法是一些URL输入或一些用于情感分析的文本输入。它只需要一个标签来命名文本框。
import streamlit as sturl = st.text_input('Enter URL')st.write('The Entered URL is', url)
该应用的外观如下:
一个简单的text_input小部件应用
提示:您可以更改文件helloworld.py并刷新浏览器。我的工作方式是打开并更改helloworld.py高级文字,并在浏览器中并排查看更改。
3.复选框
复选框的一个用例是隐藏或显示/隐藏应用程序中的特定部分。另一个可能是在函数的参数中设置布尔值。st.checkbox()接受一个参数,即小部件标签。在此应用程序中,该复选框用于切换条件语句。
import streamlit as stimport pandas as pdimport numpy as npdf = pd.read_csv("football_data.csv")if st.checkbox('Show dataframe'): st.write(df)
一个简单的复选框小部件应用
4.选择框
我们可以st.selectbox用来从系列或列表中进行选择。通常,用例是将其用作从列表中选择值的简单下拉列表。
import streamlit as stimport pandas as pdimport numpy as npdf = pd.read_csv("football_data.csv")option = st.selectbox( 'Which Club do you like best?', df['Club'].unique())'You selected: ', option
一个简单的下拉/选择框小部件应用
5.多重选择
我们还可以从下拉列表中使用多个值。在这里我们st.multiselect用来获取多个值作为变量列表options
import streamlit as stimport pandas as pdimport numpy as npdf = pd.read_csv("football_data.csv")options = st.multiselect( 'What are your favorite clubs?', df['Club'].unique())st.write('You selected:', options)
一个简单的多选小部件应用
逐步创建我们的简单应用
对于理解重要的小部件来说,就这么多。现在,我们将一次使用多个小部件创建一个简单的应用程序。
首先,我们将尝试使用streamlit可视化我们的足球数据。在上述小部件的帮助下,执行此操作非常简单。
import streamlit as stimport pandas as pdimport numpy as npdf = pd.read_csv("football_data.csv")clubs = st.multiselect('Show Player for clubs?', df['Club'].unique())nationalities = st.multiselect('Show Player from Nationalities?', df['Nationality'].unique())# Filter dataframenew_df = df[(df['Club'].isin(clubs)) & (df['Nationality'].isin(nationalities))]# write dataframe to screenst.write(new_df)
我们的简单应用程序如下所示:
结合使用多个小部件
那很简单。但是现在看来,这很基本。我们可以添加一些图表吗?
Streamlit当前支持许多绘图库。包括Plotly,Bokeh,Matplotlib,Altair和Vega图表。Plotly Express也可以使用,尽管他们没有在文档中指定。它还具有一些Streamlit原生的内置图表类型,例如st.line_chart和st.area_chart。
我们将在plotly_express这里工作。这是我们简单应用程序的代码。我们只使用了四个调用来简化。其余都是简单的python。
import streamlit as stimport pandas as pdimport numpy as npimport plotly_express as pxdf = pd.read_csv("football_data.csv")clubs = st.multiselect('Show Player for clubs?', df['Club'].unique())nationalities = st.multiselect('Show Player from Nationalities?', df['Nationality'].unique())new_df = df[(df['Club'].isin(clubs)) & (df['Nationality'].isin(nationalities))]st.write(new_df)# create figure using plotly expressfig = px.scatter(new_df, x ='Overall',y='Age',color='Name')# Plot!st.plotly_chart(fig)
添加图表
改进措施
首先,我们说过每次更改任何小部件时,整个应用程序都会从头到尾运行。当我们创建将用于深度学习模型或复杂机器学习模型的应用程序时,这是不可行的。Streamlit通过介绍Caching在这方面介绍了我们。
1.缓存
在我们简单的应用程序中。每当值更改时,我们就会一次又一次读取pandas数据框。虽然它适用于我们拥有的小数据,但不适用于大数据或当我们必须对数据进行大量处理时。让我们使用st.cache装饰器功能在以下流式处理中使用缓存。
import streamlit as stimport pandas as pdimport numpy as npimport plotly_express as pxdf = st.cache(pd.read_csv)("football_data.csv")
或者,对于仅需运行一次的更复杂且耗时的功能,请使用:
@st.cachedef complex_func(a,b): DO SOMETHING COMPLEX# Won't run again and again.complex_func(a,b)
当我们用Streamlit的缓存装饰器标记一个函数时,只要调用该函数,streamlit就会检查您调用该函数所使用的输入参数。
如果这是Streamlit第一次看到这些参数,它将运行该函数并将结果存储在本地缓存中。
下次调用该函数时,如果这些参数没有更改,则Streamlit知道它可以完全跳过执行该函数。它仅使用缓存中的结果。
2.侧边栏
为了根据您的偏好提供更整洁的外观,您可能希望将小部件移动到侧栏,例如Rshiny仪表板。这很简单。只需添加st.sidebar您的小部件的代码。
import streamlit as stimport pandas as pdimport numpy as npimport plotly_express as pxdf = st.cache(pd.read_csv)("football_data.csv")clubs = st.sidebar.multiselect('Show Player for clubs?', df['Club'].unique())nationalities = st.sidebar.multiselect('Show Player from Nationalities?', df['Nationality'].unique())new_df = df[(df['Club'].isin(clubs)) & (df['Nationality'].isin(nationalities))]st.write(new_df)# Create distplot with custom bin_sizefig = px.scatter(new_df, x ='Overall',y='Age',color='Name')# Plot!st.plotly_chart(fig)
将小部件移到侧边栏
3.Markdown?
我喜欢用Markdown写作。我发现它不如HTML冗长,更适合数据科学工作。那么,我们可以在流线型应用程序中使用Markdown吗?
我们可以。有两种方法可以做到这一点。我认为,最好的方法是使用Magic命令。魔术命令使您可以像注释一样轻松地编写markdown。您也可以使用以下命令st.markdown
import streamlit as stimport pandas as pdimport numpy as npimport plotly_express as px'''# Club and Nationality AppThis very simple webapp allows you to select and visualize players from certain clubs and certain nationalities.'''df = st.cache(pd.read_csv)("football_data.csv")clubs = st.sidebar.multiselect('Show Player for clubs?', df['Club'].unique())nationalities = st.sidebar.multiselect('Show Player from Nationalities?', df['Nationality'].unique())new_df = df[(df['Club'].isin(clubs)) & (df['Nationality'].isin(nationalities))]st.write(new_df)# Create distplot with custom bin_sizefig = px.scatter(new_df, x ='Overall',y='Age',color='Name')'''### Here is a simple chart between player age and overall'''st.plotly_chart(fig)
我们的最终应用演示
结论
Streamlit使创建应用程序的整个过程大众化,我再也推荐不了它。
在本文中,我们创建了一个简单的Web应用程序。但是可能性是无限的。在这里举个例子是流线型网站的GAN面孔。它只是通过使用小部件和缓存的相同指导思想来工作。
我喜欢开发人员使用的默认颜色和样式,并且发现它比使用Dash更加舒适,而Dash直到现在我都在演示中使用。您还可以在流式应用程序中包含音频和视频。
最重要的是,Streamlit是一个免费的开放源代码,而不是一个开箱即用的专有Web应用程序。
过去,如果演示或演示文稿有任何更改,我必须与开发人员朋友联系。现在这样做相对来说是微不足道的。
从现在开始,我打算在我的工作流程中更多地使用它,考虑到它所提供的功能而无需所有的辛苦工作,我想您也应该这样做。
我不知道它是否可以在生产环境中很好地运行,但是对于小型概念验证项目和演示来说,这是一个福音。从现在开始,我打算在我的工作流程中更多地使用它,考虑到它所提供的功能而无需所有的辛苦工作,我想您也应该这样做。
如果希望获得这篇文章的完整代码,可以私信我!
标签: #python颜色转换