虚拟货币graph,有哪些功能强大的小众app推荐?

币圈知识 阅读 3 2023-10-30 08:42:47

Bitget下载

注册下载Bitget下载,邀请好友,即有机会赢取 3,000 USDT

APP下载   官网注册

大家好,今天来为大家解答虚拟货币graph这个问题的一些问题点,包括有哪些功能强大的小众app推荐?也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

本文目录

  1. 有哪些功能强大的小众app推荐?
  2. 如何高效地使用Matplotlib?

有哪些功能强大的小众app推荐?

每个人的手机中,总有那么几款APP不没那么出名,可能是一时兴起下载的,但后来发现越来越好用,渐渐变成每天必刷的软件。这些小众且好用的软件到底有哪些呢,快一起来看看吧。

智能工具箱(smarttools):

它是一个非常强大的智能工具箱APP,提供近40种日常生活所需要的智能工具,比如:尺子、水平仪、量角器、速度、手电筒、节拍器、指南针、温度计、计步器、镜子,还有一些你可能想不到的用途:狗哨、扫描仪、测谎仪等等。它基本能解决你生活上各种小问题,但这个APP只是针对手机本身的功能并加以利用,如果你真的指望它能帮你非常专业精准的测试出各种数据,还是要寻找更专业的工具哦。

Snapseed:

作为一款操作非常简单的图片处理APP,它的功能可以说非常强大了,很多功能可以称得上是手机版Photoshop。它对于照片的整体感观、色彩和细节的处理非常到位,没有特别复杂的后期,也没有操作非常繁琐的工具,只是调整参数就能拯救你的照片。

它较其他修图APP的优势就是可以对照片进行局部调整,非常实用,可以帮助你修复照片中的小瑕疵,而不是动一下,整个照片全都改动了。对于一些想用手机修图修出大片的同学们来说,snapseed足够了。

氢应用:

氢应用的套路和微信小程序大同小异,但却比小程序早开发很久。它是一款插件容器类的应用,下载了这个APP之后,包括网易新闻、奇趣百科、开眼视频、豆瓣、微博、知乎B站等等各种你平时经常用到的软件,都可以不用再安装了。界面极简,想要的功能非常齐全。

轻芒阅读:

一款聚合了时下人们最感兴趣的各种平台的媒体、大公众号和资讯APP的杂志应用。集合各个平台的资讯到统一的轻芒阅读平台,包括知乎、36氪、豆瓣、国家地理、好奇心日报、一个,以及各种你感兴趣的公众号。如果你觉得下载太多APP太占内存,或者觉得每天看资讯各个平台切换太麻烦,下载这个APP,500+个内容平台,1000+个热门公众号,一站式浏览完所有你想看的资讯。

收趣:

收趣,顾名思义,收藏你感兴趣的。我们每天看到有趣的东西,都养成了收藏的习惯,方便稍后阅读。然而收藏的越来越多,信息又分散,很难做到每个收藏的都想起来去看。收趣可以帮你把各大平台上收藏的各种感兴趣的文章,收集在这一个APP上,它分为微信转发、复制链接、系统分享这三种收藏方式。

除了整合你的收藏情况之外,它还会将你收藏的内容统一排版,还提供语音朗读功能,还能将这些内容与kindle互通,对于喜欢用kindle读书的同学可是一项福利。

如何高效地使用Matplotlib?

引言

对新手来说Python可视化实在有些令人挫败。有很多不同的选项,如何选择正确的选项是一个挑战。例如,两年前这篇文章《OverviewofPythonVisualizationTools》(http://pbpython.com/visualization-tools-1.html)仍然吸引了大量读者。在那篇文章中,我否定了Matplotlib。但是,在使用过pandas、scikit-learn、seaborn和其他Python数据科学栈之后,我觉得之前否认Matplotlib的行为有点不成熟。坦白讲,当时我不是很了解Matplotlib,也不懂如何在我的工作流中高效使用Matplotlib。

现在我学习了一些工具,了解了如何用Matplotlib使用这些工具,Matplotlib逐渐变成了必需工具。本文将展示如何使用Matplotlib。我坚定地认为Matplotlib是Python数据科学栈必不可少的一部分,希望这篇文章可以帮助大家了解如何使用Matplotlib进行Python可视化。

为什么大家都在否定Matplotlib?

我认为,Matplotlib对于新手来说比较难存在几个原因。首先,Matplotlib有两个界面。第一个界面基于MATLAB,使用基于状态的接口。第二个界面是面向对象的接口。本文就不展开介绍Matplotlib有两个界面的原因,但了解这两种方法在使用Matplotlib绘图时会很重要。两个界面会引起混淆的原因是堆栈溢出和通过谷歌搜索获取的大量信息,新用户将发现问题的多个解决方案,但是这些问题看起来类似却不完全相同。从我的个人经验来讲,从以前的代码中,我可以看出有一些Matplotlib代码的混杂,我对此感觉很疑惑(尽管写它们的人是我……):-)

关键点

Matplotlib新手应该学习和使用面向对象的接口。

使用Matplotlib的另一个历史性挑战是一些默认的样式缺乏吸引力。在R使用ggplot就可以生成相当不错的图的世界中,Matplotlib相对来说有点丑。好消息是Matplotlib2.0中的样式好看了很多,你可以用最小的努力生成可视化。

第三个挑战是你不确定什么时候该使用Matplotlib,什么时候该使用基于Matplotlib构建的工具,如pandas或seaborn。大部分时候做一件事都有多种选择,但是对于新手来说选择正确的道路有些困难。这种混淆加上两种不同API的混淆简直就是挫败本败了……

为什么使用Matplotlib?

尽管Matplotlib有这么多问题,我还是喜欢用它,因为它很强大。这个库允许你创建几乎所有可视化。此外,围绕Matplotlib有一个丰富的Python工具生态环境,很多更高级的可视化工具使用Matplotlib作为基础库。如果你想在Python数据科学栈中进行任何操作,你需要对如何使用Matplotlib有一些基础了解。这就是本文其余部分的重点——提供一种高效使用Matplotlib的基础方法。

前提

推荐以下步骤学习如何使用Matplotlib:

1.学习Matplotlib的基本术语,具体来说就是什么是Figure和Axes。

2.一直使用面向对象的界面,养成习惯。

3.用基础的pandas绘图开始可视化。

4.使用seaborn进行稍微复杂的数据可视化。

5.使用Matplotlib自定义pandas或seaborn可视化。

下图非常重要,有助于理解图的不同术语。

大部分术语很直接易懂,需要牢记的是Figure是可能包含一或多个axes的最终图像。Axes代表单个图。一旦你理解这些是什么以及如何通过面向对象的API评估它们,其余步骤就很简单了。

了解这个知识还有一个好处,就是当你在网络上看东西的时候有一个出发点。如果你花时间了解了这个点,那么其他的MatplotlibAPI才有意义。此外,很多高级Python包,如seaborn和ggplot依赖于Matplotlib构建,因此理解了基础,学习更强大的框架才更加容易。

最后,我不是说你应该逃避其他优秀选项,如ggplot(又名ggpy)、bokeh、plotly或altair。我只是认为你需要对matplotlib+pandas+seaborn有一个基础的了解。了解基础可视化栈之后,你就可以探索其他优秀工具,根据需求做出合适的选择。

开始

下面主要介绍如何在pandas中创建基础的可视化以及使用Matplotlib定制最常用的项。了解基础流程有助于更直观地进行自定义。

我主要关注最常见的绘图任务,如标注轴、调整图形界限(limit)、更新图标题、保存图像和调整图例。

开始,我打算设置输入,读取一些数据:

importpandasaspd

importmatplotlib.pyplotasplt

frommatplotlib.tickerimportFuncFormatter

df=pd.read_excel("https://github.com/chris1610/pbpython/blob/master/data/sample-salesv3.xlsx?raw=true")

df.head()

数据包括2014年的销售交易额。为简短起见,我将总结这些数据,列出前十名客户的采购次数和交易额。绘图时我将对各列进行重命名。

top_10=(df.groupby('name')['extprice','quantity'].agg({'extprice':'sum','quantity':'count'})

.sort_values(by='extprice',ascending=False))[:10].reset_index()

top_10.rename(columns={'name':'Name','extprice':'Sales','quantity':'Purchases'},inplace=True)

下图是数据。

现在数据在简单的表格形式呈现,我们再来看一下如何将数据绘制成条形图。如前所述,Matplotlib具备多种不同风格,可用于渲染图表。你可以使用plt.style.available查看你的系统可用的风格。

plt.style.available

['seaborn-dark',

'seaborn-dark-palette',

'fivethirtyeight',

'seaborn-whitegrid',

'seaborn-darkgrid',

'seaborn',

'bmh',

'classic',

'seaborn-colorblind',

'seaborn-muted',

'seaborn-white',

'seaborn-talk',

'grayscale',

'dark_background',

'seaborn-deep',

'seaborn-bright',

'ggplot',

'seaborn-paper',

'seaborn-notebook',

'seaborn-poster',

'seaborn-ticks',

'seaborn-pastel']

使用如下简单风格:

plt.style.use('ggplot')

我鼓励大家使用不同的风格,找到自己喜欢的。

现在我们有了好看的风格,第一步就是使用标准pandas绘图函数绘制数据:

top_10.plot(kind='barh',y="Sales",x="Name")

推荐使用pandas绘图的原因在于它是一种快速便捷地建立可视化原型的方式。

自定义图表

如果你对该图表的重要部分都很满意,那么下一步就是对它执行自定义。一些自定义(如添加标题和标签)可以使用pandasplot函数轻松搞定。但是,你可能会发现自己需要在某个时刻跳出来。这就是我推荐你养成以下习惯的原因:

fig,ax=plt.subplots()

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax)

生成的图表和原始图表基本一样,不过我们向plt.subplots()添加了一个额外的调用,并将ax传输至绘图函数。为什么要这么做呢?还记得我说在Matplotlib中获取轴和图像非常关键吗?这里所做的就是为了达到该目的。通过ax或fig对象可以执行任何自定义。

我们利用pandas实现快速绘图,现在利用Matplotlib获取所有功能。通过使用命名惯例,调整别人的解决方案适应自己的需求变得更加直接简单了。

假设我们想调整x极限,改变一些轴标签。现在我们在ax变量中有多个轴,可以进行一些操作:

fig,ax=plt.subplots()

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax)

ax.set_xlim([-10000,140000])

ax.set_xlabel('TotalRevenue')

ax.set_ylabel('Customer');

这是另一种改变标题和标签的简单方式:

fig,ax=plt.subplots()

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax)

ax.set_xlim([-10000,140000])

ax.set(title='2014Revenue',xlabel='TotalRevenue',ylabel='Customer')

为了进一步展示该方法,我们还可以调整图像大小。使用plt.subplots()函数可以定义figsize,以英寸为单位。我们还可以使用ax.legend().set_visible(False)移除图例。

fig,ax=plt.subplots(figsize=(5,6))

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax)

ax.set_xlim([-10000,140000])

ax.set(title='2014Revenue',xlabel='TotalRevenue')

ax.legend().set_visible(False)

要想修改这个图像,你可能需要执行很多操作。图中最碍眼的可能是总收益额的格式。Matplotlib可以使用FuncFormatter解决这一问题。该函数用途多样,允许用户定义的函数应用到值,并返回格式美观的字符串。

以下是货币格式化函数,用于处理数十万美元区间的数值:

defcurrency(x,pos):

'Thetwoargsarethevalueandtickposition'

ifx>=1000000:

return'${:1.1f}M'.format(x*1e-6)

return'${:1.0f}K'.format(x*1e-3)

现在我们有了格式化程序函数,就需要定义它,并将其应用到x轴。完整代码如下:

fig,ax=plt.subplots()

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax)

ax.set_xlim([-10000,140000])

ax.set(title='2014Revenue',xlabel='TotalRevenue',ylabel='Customer')

formatter=FuncFormatter(currency)

ax.xaxis.set_major_formatter(formatter)

ax.legend().set_visible(False)

这张图美观多了,非常好地展示了自定义问题解决方案的灵活性。最后要说的自定义特征是向图表添加注释。你可以使用ax.axvline()画垂直线,使用ax.text()添加自定义文本。就以上示例,我们可以画一条表示平均值的线,包括代表3个新客户的标签。以下是完整代码:

#Createthefigureandtheaxes

fig,ax=plt.subplots()

#Plotthedataandgettheaveraged

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax)

avg=top_10['Sales'].mean()

#Setlimitsandlabels

ax.set_xlim([-10000,140000])

ax.set(title='2014Revenue',xlabel='TotalRevenue',ylabel='Customer')

#Addalinefortheaverage

ax.axvline(x=avg,color='b',label='Average',linestyle='--',linewidth=1)

#Annotatethenewcustomers

forcustin[3,5,8]:

ax.text(115000,cust,"NewCustomer")

#Formatthecurrency

formatter=FuncFormatter(currency)

ax.xaxis.set_major_formatter(formatter)

#Hidethelegend

ax.legend().set_visible(False)

这可能不是最壮观的图,但它确实展示了使用该方法的力量。

图表

目前,我们所做的所有改变都是针对单个图表。我们还能够在图像上添加多个表,使用不同的选项保存整个图像。

如果我们确定要在同一个图像上放置两个表,那么我们应该对如何做有一个基础了解。首先,创建图像,然后创建轴,再将它们绘制成图表。使用plt.subplots()可以完成该操作:

fig,(ax0,ax1)=plt.subplots(nrows=1,ncols=2,sharey=True,figsize=(7,4))

在这个例子中,我使用nrows和ncols指定大小,这对新用户来说比较清晰易懂。

在示例代码中,你会经常看到变量如1、2。我认为使用命名参数便于稍后查看代码时理解代码。

我还使用sharey=True以使y轴共享相同的标签。

该示例很灵活,因为不同的轴可以解压成ax0和ax1。现在我们有了这些轴,就可以像上述示例中那样绘图,然后把一个图放在ax0上,另一个图放在ax1。

#Getthefigureandtheaxes

fig,(ax0,ax1)=plt.subplots(nrows=1,ncols=2,sharey=True,figsize=(7,4))

top_10.plot(kind='barh',y="Sales",x="Name",ax=ax0)

ax0.set_xlim([-10000,140000])

ax0.set(title='Revenue',xlabel='TotalRevenue',ylabel='Customers')

#Plottheaverageasaverticalline

avg=top_10['Sales'].mean()

ax0.axvline(x=avg,color='b',label='Average',linestyle='--',linewidth=1)

#Repeatfortheunitplot

top_10.plot(kind='barh',y="Purchases",x="Name",ax=ax1)

avg=top_10['Purchases'].mean()

ax1.set(title='Units',xlabel='TotalUnits',ylabel='')

ax1.axvline(x=avg,color='b',label='Average',linestyle='--',linewidth=1)

#Titlethefigure

fig.suptitle('2014SalesAnalysis',fontsize=14,fontweight='bold');

#Hidethelegends

ax1.legend().set_visible(False)

ax0.legend().set_visible(False)

现在,我已经在jupyternotebook中用%matplotlibinline展示了很多图像。但是,在很多情况下你需要以特定格式保存图像,将其和其他呈现方式整合在一起。

Matplotlib支持多种不同文件保存格式。你可以使用fig.canvas.get_supported_filetypes()查看系统支持的文件格式:

fig.canvas.get_supported_filetypes()

{'eps':'EncapsulatedPostscript',

'jpeg':'JointPhotographicExpertsGroup',

'jpg':'JointPhotographicExpertsGroup',

'pdf':'PortableDocumentFormat',

'pgf':'PGFcodeforLaTeX',

'png':'PortableNetworkGraphics',

'ps':'Postscript',

'raw':'RawRGBAbitmap',

'rgba':'RawRGBAbitmap',

'svg':'ScalableVectorGraphics',

'svgz':'ScalableVectorGraphics',

'tif':'TaggedImageFileFormat',

'tiff':'TaggedImageFileFormat'}

我们有fig对象,因此我们可以将图像保存成多种格式:

fig.savefig('sales.png',transparent=False,dpi=80,bbox_inches="tight")

该版本将图表保存为不透明背景的png文件。我还指定dpi和bbox_inches="tight"以最小化多余空白。

结论

希望该方法可以帮助大家理解如何更有效地使用Matplotlib进行日常数据分析。

END,本文到此结束,如果可以帮助到大家,还望关注本站哦!

相关内容

标签: matplotlib seaborn 使用

虚拟货币graph,有哪些功能强大的小众app推荐?文档下载: PDF DOC TXT
文章来源: 小易
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至举报,一经查实,本站将立刻删除。
上一篇: 虚拟货币goodluck GoodLuck是什么意思 下一篇: 虚拟货币都有哪些指标呢,虚拟货币的基本属性

相关资讯