溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

發(fā)布時(shí)間:2022-01-21 15:10:09 來(lái)源:億速云 閱讀:218 作者:iii 欄目:開(kāi)發(fā)技術(shù)

今天小編給大家分享一下Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

SVG是一種可縮放的二維矢量圖形標(biāo)準(zhǔn),用于提供高質(zhì)量的矢量圖形渲染,SVG具有非常強(qiáng)的開(kāi)放性,所以其在應(yīng)用的過(guò)程中主要的對(duì)象是網(wǎng)絡(luò)。

環(huán)境:Ubuntu 18.04 LTS

Python版本:Python 3.6.7

首先要安裝 pygal:

linuxidc@linuxidc:~/linuxidc.com$ pip3 install pygal
Collecting pygal
Downloading https://files.pythonhosted.org/packages/5f/b7/201c9254ac0d2b8ffa3bb2d528d23a4130876d9ba90bc28e99633f323f17/pygal-2.4.0-py2.py3-none-any.whl (127kB)
100% |████████████████████████████████| 133kB 231kB/s
Installing collected packages: pygal
Successfully installed pygal-2.4.0

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

如果你要把生成格式設(shè)為除了 svg 之外的格式,比如 png,jpg 圖片格式,就要安裝以下這幾個(gè)庫(kù)了:

linuxidc@linuxidc:~/linuxidc.com$ pip3 install lxml -i https://pypi.douban.com/simple/

Collecting lxml
Downloading https://pypi.doubanio.com/packages/35/8a/5e066949f2b40caac32c7b2a77da63ad304b5fbe869036cc3fe4a198f724/lxml-4.3.3-cp36-cp36m-manylinux1_x86_64.whl (5.7MB)
100% |████████████████████████████████| 5.7MB 12.6MB/s
Installing collected packages: lxml
Successfully installed lxml-4.3.3

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

在 Ubuntu 中按照如下提示安裝即可:

linuxidc@linuxidc:~/linuxidc.com$ sudo apt-get install libxml2-dev libxslt1-dev python-dev

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

linuxidc@linuxidc:~/linuxidc.com$ sudo apt-get install python-lxml

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

linuxidc@linuxidc:~/linuxidc.com$ pip3 install cairosvg -i https://pypi.douban.com/simple/

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形
安裝該庫(kù)原理同上:

linuxidc@linuxidc:~/linuxidc.com$ sudo apt-get install python-cairosvg

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

如下兩個(gè)庫(kù),只需正常 pip3 安裝即可:

linuxidc@linuxidc:~/linuxidc.com$ pip3 install tinycss -i https://pypi.douban.com/simple/
Collecting tinycss
Downloading https://pypi.doubanio.com/packages/05/59/af583fff6236c7d2f94f8175c40ce501dcefb8d1b42e4bb7a2622dff689e/tinycss-0.4.tar.gz (87kB)
100% |████████████████████████████████| 92kB 824kB/s
Building wheels for collected packages: tinycss
Running setup.py bdist_wheel for tinycss … done
Stored in directory: /home/linuxidc/.cache/pip/wheels/00/1e/22/af03548f887c6f9a423f72f819c46a4df9e2aabbb9480be30b
Successfully built tinycss
Installing collected packages: tinycss
Successfully installed tinycss-0.4

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

linuxidc@linuxidc:~/linuxidc.com$ pip3 install cssselect -i https://pypi.douban.com/simple/
Collecting cssselect
Downloading https://pypi.doubanio.com/packages/7b/44/25b7283e50585f0b4156960691d951b05d061abf4a714078393e51929b30/cssselect-1.0.3-py2.py3-none-any.whl
Installing collected packages: cssselect
Successfully installed cssselect-1.0.3

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

Hello SVG

import pygal
bar_chart = pygal.Bar()
bar_chart.add(‘linuxidc’, [0, 1, 1, 5, 6, 8, 13, 22, 35, 55])
bar_chart.render_to_file(‘linuxidc.com.svg’)

在當(dāng)前目錄生成的是黑色的 linuxidc.com.svg 文件,因?yàn)槭?svg 格式的,一般的話直接是不能打開(kāi)的,選擇默認(rèn)的瀏覽器打開(kāi)吧,看到就是底下這個(gè)樣子:

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

更加炫酷點(diǎn)的圖:

import pygal
line_chart = pygal.Line()
line_chart.title = ‘Browser usage evolution (in %)’
line_chart.x_labels = map(str, range(2002, 2013))
line_chart.add(‘Firefox’, [None, None, 0, 16.6, 25, 31, 36.4, 45.5, 46.3, 42.8, 37.1])
line_chart.add(‘Chrome’, [None, None, None, None, None, None, 0, 3.9, 10.8, 23.8, 35.3])
line_chart.add(‘IE’,  [85.8, 84.6, 84.7, 74.5, 66, 58.6, 54.7, 44.8, 36.2, 26.6, 20.1])
line_chart.add(‘Others’, [14.2, 15.4, 15.3, 8.9, 9, 10.4, 8.9, 5.8, 6.7, 6.8, 7.5])
line_chart.render_to_file(‘www.linuxidc.com.svg’)

生成的圖就是下面這個(gè)樣子:

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

有時(shí)候,我們不需要 svg,只需要 png 格式的圖表,沒(méi)關(guān)系,pygal 也能夠做到:

import pygal
bar_chart = pygal.Bar()
bar_chart.add(‘linuxidc’, [0, 1, 1, 5, 7, 8, 15, 21, 35, 60])
bar_chart.render_to_file(‘linux.linuxidc.com.svg’)
# 生成 png 格式圖表
bar_chart.render_to_png(filename=’linux.linuxidc.com.png’)

成功生成 png 格式的圖片:

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

讓 Pygal 生成的 svg 格式圖片中,顯示在你的網(wǎng)頁(yè)上唄,我們選擇 flask 來(lái)提供 web 支持:

linuxidc@linuxidc:~/linuxidc.com$ pip3 install flask -i https://pypi.douban.com/simple/

核心代碼如下,沒(méi)錯(cuò)就是這么短:

import pygal
from flask import Flask
app = Flask(__name__)
@app.route(‘/’)
def drawSVG():
line_chart = pygal.Line(legend_at_bottom=True,legend_box_size=18)
line_chart.title = ‘Browser usage evolution (in %)’
line_chart.x_labels = map(str, range(2002, 2013))
line_chart.add(‘Firefox’, [None, None, 0, 16.6,  25,  31, 36.4, 45.5, 46.3, 42.8, 37.1])
line_chart.add(‘Chrome’,  [None, None, None, None, None, None,    0,  3.9, 10.8, 23.8, 35.3])
line_chart.add(‘IE’,      [85.8, 84.6, 84.7, 74.5,  66, 58.6, 54.7, 44.8, 36.2, 26.6, 20.1])
line_chart.add(‘Others’,  [14.2, 15.4, 15.3,  8.9,    9, 10.4,  8.9,  5.8,  6.7,  6.8,  7.5])
svg = line_chart.render_response()
return svg
if __name__ == ‘__main__’:
app.run()
打開(kāi) 127.0.0.1:5000 就能看到下面的樣子咯:

Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形

以上就是“Ubuntu下怎么使用Python的pygal庫(kù)創(chuàng)建SVG矢量圖形”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI