欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于python詳解PyScript到底是什么

 更新時(shí)間:2022年06月13日 16:53:46   作者:??Python編程學(xué)習(xí)圈????  
這篇文章主要介紹了基于python詳解PyScript到底是什么?文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值需要的朋友可以參考一下下面文章內(nèi)容

前言:

最近 Anaconda 開大會(huì)發(fā)布了 PyScript ,它允許我們將 Python 代碼嵌入到 HTML 中,并在瀏覽器中允許。PyScript 旨在為用戶提供一流的編程語言,該語言具有一致的樣式規(guī)則、更具表現(xiàn)力且更易于學(xué)習(xí)。

熟悉前端的朋友應(yīng)該馬上就可以反應(yīng)到:這就是替代 JavaScript ?。?/p>

確實(shí),這個(gè)功能就類似于 JavaScript,如果后面發(fā)展得好的話,我們完全可以不寫 JavaScript,直接寫 Python 也能實(shí)現(xiàn)一樣的效果。

這個(gè)項(xiàng)目出來之后,馬上躥升到 GitHub 趨勢榜榜首,短短20天已經(jīng)有 10K+ 的 star 了,可見其熱度之高。

我們不知道 anaconda 有沒有這個(gè)野心,但是 PyScript 的出現(xiàn),確實(shí)是一件振奮人心的事情,意味著你會(huì) Python 的話,再加上前端知識(shí),就可以寫出漂亮的前端頁面了。對于 Pythoner 來說,我們可以用 Python 和 HTML前端知識(shí)做全棧工程師了。

作用

PyScript 核心特性:

  • Python in the browser:啟用 drop-in content、外部文件托管(基于 Pyodide 項(xiàng)目),以及不依賴服務(wù)器端配置的應(yīng)用程序托管。
  • Python 生態(tài):提供流行的 Python 和科學(xué)計(jì)算軟件包(例如 numpy, pandas, scikit-learn 等)。
  • Python with JavaScript:在 Python 和 JavaScript 對象和命名空間之間進(jìn)行雙向通信。
  • 環(huán)境管理:開發(fā)者可定義要引入哪些包和文件,以便頁面代碼的運(yùn)行。
  • 可視化應(yīng)用開發(fā):開發(fā)者可使用現(xiàn)成的 UI 組件,如按鈕、容器、文本框等。
  • 靈活的框架:開發(fā)者可以利用它在 Python 中直接創(chuàng)建和分享新的可插拔和可擴(kuò)展的組件。

PyScript 目標(biāo):

  • 提供干凈簡單的 API。
  • 支持標(biāo)準(zhǔn) HTML。
  • 擴(kuò)展 HTML 以讀取穩(wěn)定且可靠的自定義組件。
  • 提供可插拔、可擴(kuò)展的組件系統(tǒng)。

使用方法

下面,我們來體驗(yàn)一下這個(gè)新生事物吧!

我們可以使用 CDN 來安裝 PyScript:

<link?rel="stylesheet"? rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ?/>
<script?defer?src="https://pyscript.net/alpha/pyscript.js"></script>

接著,我們來看看一個(gè)簡單的頁面:

<!DOCTYPE?html>
<html?lang="en">
<head>
????<meta?charset="UTF-8">
????<meta?http-equiv="X-UA-Compatible"?content="IE=edge">
????<meta?name="viewport"?content="width=device-width,?initial-scale=1.0">
????<!--?引入?PyScript?-->
????<link?rel="stylesheet"? rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ?/>
????<script?defer?src="https://pyscript.net/alpha/pyscript.js"></script>
????<title>First?PyScript?Application</title>
????<style>
????????py-script?{
????????????width:?100%;
????????????height:?100%;
????????????font-size:?20px;
????????????text-align:?center;
????????????position:?absolute;
????????}
????</style>
</head>
<body>
????<py-script>
????????print('Hello?PyScript!')
????</py-script>
</body>
</html>

運(yùn)行這個(gè)程序,你就可以在瀏覽器頁面上看到這個(gè)結(jié)果了:

這就是我們著名的Hello式問候!

這段前端代碼里面,我們直接使用py-script標(biāo)簽包裹 Python 代碼,就實(shí)現(xiàn)前端腳本控制功能了。

我這里是在 vscode 里面運(yùn)行的,運(yùn)行代碼之前需要安裝Live Server這個(gè)插件,然后就可以直接瀏覽器訪問了。

我們再來看一個(gè)復(fù)雜一點(diǎn)的例子:

<html>
????<head>
??????<link?rel="stylesheet"? rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ?/>
??????<script?defer?src="https://pyscript.net/alpha/pyscript.js"></script>
??????<link? rel="external nofollow" ?rel="stylesheet"?crossorigin="anonymous">
????</head>

??<body>
????<b><p>Today?is?<u><label?id='today'></label></u></p></b>
????<br>
????<div?id="pi"?class="alert?alert-primary"></div>
????<py-script>
????????import?datetime?as?dt
????????pyscript.write('today',?dt.date.today().strftime('%A?%B?%d,?%Y'))

????????def?compute_pi(n):
????????????pi?=?2
????????????for?i?in?range(1,n):
????????????????pi?*=?4?*?i?**?2?/?(4?*?i?**?2?-?1)
????????????return?pi

????????pi?=?compute_pi(100000)
????????pyscript.write('pi',?f'π?is?approximately?{pi:.3f}')
????</py-script>
??</body>
</html>

這個(gè)例子中,我們使用<py-script>標(biāo)簽,在里面提供.write()方法,將字符串寫到頁面的標(biāo)簽中。

運(yùn)行這段代碼,我們會(huì)看到瀏覽器頁面的結(jié)果:

我們還可以在頁面中引入 Python 的包,來實(shí)現(xiàn)一些簡便的操作。

<html>
????<head>
??????<link?rel="stylesheet"? rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ?/>
??????<script?defer?src="https://pyscript.net/alpha/pyscript.js"></script>
??????<py-env>
????????-?numpy
????????-?matplotlib
??????</py-env>
????</head>
??<body>
????<h1>Let's?plot?random?numbers</h1>
????<div?id="plot"></div>
????<py-script?output="plot">
????????import?matplotlib.pyplot?as?plt
????????import?numpy?as?np
????????x?=?np.random.randn(1000)
????????y?=?np.random.randn(1000)

????????fig,?ax?=?plt.subplots()
????????ax.scatter(x,?y)
????????fig
????</py-script>
??</body>
</html>

在這里,我們引用了numpymatplotlib這兩個(gè)包,引用包是在<head>標(biāo)簽內(nèi)部通過<py-env>標(biāo)簽來實(shí)現(xiàn)。

運(yùn)行這個(gè)程序,我的頁面始終處于加載狀態(tài):

現(xiàn)階段,運(yùn)行帶有 PyScript 的頁面加載速度還是有點(diǎn)感人的,好像一下子回到了原始年代。所以,想要被大家廣泛使用還有很長的路要走。

目前階段,我們還只能繼續(xù)等待,想要嘗鮮的話,可以在去 GitHub 上看看。在公眾號后臺(tái)留言PyScript獲取項(xiàng)目的 GitHub 地址。

總結(jié)

項(xiàng)目現(xiàn)在還在完善階段,許多功能還沒有支持,但是從其熱度和參與貢獻(xiàn)的人數(shù)來看,前途還是光明的,畢竟 Python 有著這么多的應(yīng)用基礎(chǔ),學(xué)會(huì) Python 就可以寫前端, Python 的那些便捷操作庫都可以在頁面直接使用的話,會(huì)大大提高大家的效率,我們也不用去學(xué)習(xí)現(xiàn)在越來越復(fù)雜的那一套前端技術(shù)了。

到此這篇關(guān)于基于python詳解PyScript到底是什么的文章就介紹到這了,更多相關(guān)python PyScript內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python?程序通過可執(zhí)行文件部署方式

    Python?程序通過可執(zhí)行文件部署方式

    這篇文章主要介紹了Python?程序通過可執(zhí)行文件部署方式,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • pygame實(shí)現(xiàn)俄羅斯方塊游戲(AI篇2)

    pygame實(shí)現(xiàn)俄羅斯方塊游戲(AI篇2)

    這篇文章主要為大家詳細(xì)介紹了pygame實(shí)現(xiàn)俄羅斯方塊游戲AI的第2篇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Python Pywavelet 小波閾值實(shí)例

    Python Pywavelet 小波閾值實(shí)例

    今天小編就為大家分享一篇Python Pywavelet 小波閾值實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • 使用python框架Scrapy爬取數(shù)據(jù)的操作步驟

    使用python框架Scrapy爬取數(shù)據(jù)的操作步驟

    Scrapy是一個(gè)基于Python的強(qiáng)大的開源網(wǎng)絡(luò)爬蟲框架,用于從網(wǎng)站上抓取信息,它提供了廣泛的功能,使得爬取和分析數(shù)據(jù)變得相對容易,本文小編將給給大家介紹一下如何使用python框架Scrapy爬取數(shù)據(jù),需要的朋友可以參考下
    2023-10-10
  • Python3 無重復(fù)字符的最長子串的實(shí)現(xiàn)

    Python3 無重復(fù)字符的最長子串的實(shí)現(xiàn)

    這篇文章主要介紹了Python3 無重復(fù)字符的最長子串的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • zip在python中的用法小結(jié)

    zip在python中的用法小結(jié)

    Python中的zip函數(shù)是一個(gè)非常有用的工具,可以幫助我們同時(shí)處理多個(gè)可迭代對象,通過使用zip函數(shù),我們可以將多個(gè)列表或迭代器中的元素打包成一個(gè)個(gè)元組,然后返回由這些元組組成的列表,這篇文章介紹zip在python中的用法,感興趣的朋友一起看看吧
    2024-02-02
  • Python使用selenium實(shí)現(xiàn)網(wǎng)頁用戶名 密碼 驗(yàn)證碼自動(dòng)登錄功能

    Python使用selenium實(shí)現(xiàn)網(wǎng)頁用戶名 密碼 驗(yàn)證碼自動(dòng)登錄功能

    這篇文章主要介紹了Python使用selenium實(shí)現(xiàn)網(wǎng)頁用戶名 密碼 驗(yàn)證碼自動(dòng)登錄功能,實(shí)現(xiàn)思路很簡單,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • Python提取PDF中的圖片的實(shí)現(xiàn)示例

    Python提取PDF中的圖片的實(shí)現(xiàn)示例

    本文主要介紹了Python提取PDF中的圖片的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Python自動(dòng)化辦公技巧分享

    Python自動(dòng)化辦公技巧分享

    Python自動(dòng)化辦公是指用Python程序來完成某些需要重復(fù)性操作的工作,例如大批量的文件處理等,本篇文章將介紹Python自動(dòng)化辦公的基本概念和常用技術(shù),希望能對Python初學(xué)者提供一些幫助
    2023-06-06
  • Python爬蟲程序中使用生產(chǎn)者與消費(fèi)者模式時(shí)進(jìn)程過早退出的問題

    Python爬蟲程序中使用生產(chǎn)者與消費(fèi)者模式時(shí)進(jìn)程過早退出的問題

    本文主要介紹了Python爬蟲程序中使用生產(chǎn)者與消費(fèi)者模式時(shí)進(jìn)程過早退出的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01

最新評論