Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 曰韩美女一级视频,精品久久国产,国产1区2区三区不卡

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          5分鐘學會用Python Jinja2模板引擎渲染HTML網頁

          深入Python Web開發的過程中,HTML模板渲染是構建動態Web應用的重要環節。今天將詳細探討如何使用Python中最流行的模板引擎之一——Jinja2來進行高效且靈活的模板渲染。通過具體的代碼示例,將了解如何結合Flask框架與Jinja2實現數據與視圖的完美分離。

          Jinja2簡介

          Jinja2是一個強大的現代模板引擎,設計用于Python web開發項目,它支持變量替換、控制結構、過濾器和宏等豐富的功能。Flask框架默認集成并推薦使用Jinja2進行模板渲染,使其成為Python Web開發者手中不可或缺的工具。

          安裝與配置Jinja2(適用于未安裝Flask環境)

          如果已經安裝過Flask,Jinja2通常已隨Flask一同安裝。若需要單獨安裝:

          pip install Jinja2

          基本使用示例

          1.創建模板文件

          在項目中創建一個名為templates的文件夾,并在其內放置我們的HTML模板文件,例如index.html:

          <!-- templates/index.html -->
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html渲染示例</title>
          </head>
          <body>
              <h1>{{ title }}</h1>
              <p>Welcome to {{ site_name }}!</p>
              <ul>
              {% for item in items %}
                  <li>{{ item }}</li>
              {% endfor %}
              </ul>
          </body>
          </html>

          在這個模板中,我們用{{ variable }}表示變量占位符,{% %}表示控制結構

          2.Flask中加載和渲染模板

          在Flask應用中,我們需要導入render_template函數來加載并渲染模板:

          from flask import Flask, render_template
          
          app = Flask(__name__)
          
          @app.route('/')
          def home():
              # 定義傳遞給模板的數據
              title = '主頁'
              site_name = 'Html模板渲染示例'
              items = ['Item 1', 'Item 2', 'Item 3']
          
              # 渲染模板并將數據傳遞給模板
              return render_template('index.html', title=title, site_name=site_name, items=items)
          
          if __name__ == '__main__':
              app.run(debug=True)

          當用戶訪問主頁時,Flask會調用home函數,其中render_template函數會查找templates目錄下的index.html模板,并將定義好的變量替換到相應的位置。

          Jinja2高級特性

          1. 控制結構

          除了簡單的循環外,Jinja2還支持條件判斷和其他邏輯操作:

          <!-- 在模板中添加條件判斷 -->
          {% if user.is_authenticated %}
              <p>Welcome, {{ user.username }}!</p>
          {% else %}
              <p>Please log in.</p>
          {% endif %}

          2. 過濾器

          Jinja2內置了眾多過濾器,可以對變量進行處理,如格式化日期、轉換大小寫等:

          <!-- 使用過濾器格式化日期 -->
          <p>The date is: {{ current_date|date("Y-m-d") }}</p>

          3. 宏

          宏允許復用或封裝常見的HTML片段,提高代碼可讀性和維護性:

          {# 在一個單獨的macros.html模板中定義宏 #}
          {% macro render_item(item) %}
              <div class="item">
                  <h3>{{ item.title }}</h3>
                  <p>{{ item.description }}</p>
              </div>
          {% endmacro %}

          然后在其他模板中引入并使用該宏:

          {% from 'macros.html' import render_item %}
          
          <ul>
          {% for item in items %}
              {{ render_item(item) }}
          {% endfor %}
          </ul>

          結語

          通過本文,我們已經深入了解了Jinja2模板引擎的基礎使用方法以及其高級特性。掌握好Jinja2能夠顯著提升你的Web應用開發效率,實現更復雜、更美觀的動態頁面布局。

          關注我,手把手帶你快速入門Python Web編程!

          markdown中寫下你的文章,并使用Python將它們轉換成HTML-作者Florian Dahlitz,于2020年5月18日(15分鐘)

          介紹

          幾個月前,我想開通自己的博客,而不是使用像Medium這樣的網站。這是一個非常基礎的博客,所有的文章都是HTML形式的。然而,有一天,我突然產生了自己編寫Markdown到HTML生成器的想法,最終這將允許我用markdown來編寫文章。此外,為它添加諸如估計閱讀時間之類的擴展特性會更容易。長話短說,我實現了自己的markdown到HTML生成器,我真的很喜歡它!

          在本系列文章中,我想向您展示如何構建自己的markdown到HTML生成器。該系列由三部分組成:

          • 第一部分(本文)介紹了整個管線的實現。

          • 第二部分通過一個模塊擴展了實現的管線,該模塊用于計算給定文章的預計閱讀時間。

          • 第三部分演示如何使用管線生成自己的RSS摘要。

          這三部分中使用的代碼都可以在GitHub上找到。

          備注:我的文章中markdown到HTML生成器的想法基于Anthony Shaw文章中的實現。

          項目構建

          為了遵循本文的內容,您需要安裝幾個軟件包。我們把它們放進requirements.txt文件。

          Markdown是一個包,它允許您將markdown代碼轉換為HTML。之后我們用Flask產生靜態文件。

          但在安裝之前,請創建一個虛擬環境,以避免Python安裝出現問題:

          激活后,您可以使用pip安裝requirements.txt中的依賴。

          很好!讓我們創建幾個目錄來更好地組織代碼。首先,我們創建一個app目錄。此目錄包含我們提供博客服務的Flask應用程序。所有后續目錄都將在app目錄內創建。其次,我們創建一個名為posts的目錄。此目錄包含要轉換為HTML文件的markdown文件。接下來,我們創建一個templates目錄,其中包含稍后使用Flask展示的模板。在templates目錄中,我們再創建兩個目錄:

          posts包含生成的HTML文件,這些文件與應用程序根目錄中posts目錄中的文件相對應。

          shared包含在多個文件中使用的HTML文件。

          此外,我們還創建了一個名為services的目錄。該目錄將包含我們在Flask應用程序中使用的模塊,或者為它生成某些東西。最后,創建一個名為static的目錄帶有兩個子目錄images和css。自定義CSS文件和文章的縮略圖將存儲在此處。

          您的最終項目結構應如下所示:

          令人驚嘆!我們完成了一般的項目設置。我們來看看Flask的設置。

          Flask設置

          路由

          我們在上一節安裝了Flask。但是,我們仍然需要一個Python文件來定義用戶可以訪問的端點。在app目錄中創建main.py并將以下內容復制到其中。

          該文件定義了一個具有兩個端點的基礎版Flask應用程序。用戶可以使用/route訪問第一個端點返回索引頁,其中列出了所有文章。

          第二個端點是更通用的端點。它接受post的名稱并返回相應的HTML文件。

          接下來,我們通過向app目錄中添加一個__init__.py,將其轉換為一個Python包。此文件為空。如果您使用UNIX計算機,則可以從項目的根目錄運行以下命令:

          模板

          現在,我們創建兩個模板文件index.html以及layout.html,都存儲在templates/shared目錄中。這個layout.html模板將用于單個博客條目,而index.html模板用于生成索引頁,從中我們可以訪問每個帖子。讓我們從index.html模板開始。

          它是一個基本的HTML文件,其中有兩個元標記、一個標題和兩個樣式表。注意,我們使用一個遠程樣式表和一個本地樣式表。遠程樣式表用于啟用Bootstrap[1]類。第二個是自定義樣式。我們晚點再定義它們。

          HTML文件的主體包含一個容器,其中包含Jinja2[2]邏輯,用于為每個post生成Bootstrap卡片[3]。您是否注意到我們不直接基于變量名訪問這些值,而是需要將[0]添加到其中?這是因為文章中解析的元數據是列表。實際上,每個元數據元素都是由單一元素組成的列表。我們稍后再看。到目前為止,還不錯。讓我們看看layout.html模板。

          如你所見,它比前一個短一點,簡單一點。文件頭與index.html文件很相似,除了我們有不同的標題。當然,我們可以共用一個模板,但是我不想讓事情變得更復雜。

          body中的容器僅定義一個h1標記。然后,我們提供給模板的內容被插入并呈現。

          樣式

          正如上一節所承諾的,我們將查看自定義CSS文件style.css. 我們在static/css中找到該文件,并根據需要自定義頁面。下面是我們將用于基礎示例的內容:

          我不喜歡Bootstrap中blockquotes的默認外觀,所以我們在左側添加了一點間距和邊框。此外,blockquote段落底部的頁邊空白將被刪除。不刪除的話看起來很不自然。

          最后但并非最不重要的是,左右兩邊的填充被刪除。由于兩邊都有額外的填充,縮略圖沒有正確對齊,所以在這里刪除它們。

          到現在為止,一直都還不錯。我們完成了關于Flask的所有工作。讓我們開始寫一些帖子吧!

          寫文章

          正如標題所承諾的,你可以用markdown寫文章-是的!在寫文章的時候,除了保證正確的markdown格式外,沒有其他需要注意的事情。

          在完成本文之后,我們需要在文章中添加一些元數據。此元數據添加在文章之前,并由三個破折號分隔開來---。下面是一個示例文章(post1.md)的摘錄:

          注意:您可以在GitHub庫的app/posts/post1.md中找到完整的示例文章。

          在我們的例子中,元數據由標題、副標題、類別、發布日期和index.html中卡片對應縮略圖的路徑組成.

          我們在HTML文件中使用了元數據,你還記得嗎?元數據規范必須是有效的YAML。示例形式是鍵后面跟著一個冒號和值。最后,冒號后面的值是列表中的第一個也是唯一的元素。這就是我們通過模板中的索引運算符訪問這些值的原因。

          假設我們寫完了文章。在我們可以開始轉換之前,還有一件事要做:我們需要為我們的帖子生成縮略圖!為了讓事情更簡單,只需從你的電腦或網絡上隨機選取一張圖片,命名它為placeholder.jpg并把它放到static/images目錄中。GitHub存儲庫中兩篇文章的元數據包含一個代表圖像的鍵值對,值是placeholder.jpg。

          注意:在GitHub存儲庫中,您可以找到我提到的兩篇示例文章。

          markdown到HTML轉換器

          最后,我們可以開始實現markdown to HTML轉換器。因此,我們使用我們在開始時安裝的第三方包Markdown。我們先創建一個新模塊,轉換服務將在其中運行。因此,我們在service目錄中創建了converter.py。我們一步一步看完整個腳本。您可以在GitHub存儲庫中一次查看整個腳本。

          首先,我們導入所需的所有內容并創建幾個常量:

          ROOT指向我們項目的根。因此,它是包含app的目錄。

          POSTS_DIR是以markdown編寫的文章的路徑。

          TEMPLATE_DIR分別指向對應的templates目錄。

          BLOG_TEMPLATE_文件存儲layout.html的路徑。

          INDEX_TEMPLATE_FILE是index.html

          BASE_URL是我們項目的默認地址,例如。https://florian-dahlitz.de.默認值(如果不是通過環境變量DOMAIN提供的話)是http://0.0.0.0:5000。

          接下來,我們創建一個名為generate_entries的新函數。這是我們定義的唯一一個轉換文章的函數。

          在函數中,我們首先獲取POSTS_DIR目錄中所有markdown文件的路徑。pathlib的awesome glob函數幫助我們實現它。

          此外,我們定義了Markdown包需要使用的擴展。默認情況下,本文中使用的所有擴展都隨它的安裝一起提供。

          注意:您可以在文檔[4]中找到有關擴展的更多信息。

          此外,我們實例化了一個新的文件加載程序,并創建了一個在轉換項目時使用的環境。隨后,將創建一個名為all_posts的空列表。此列表將包含我們處理后的所有帖子。現在,我們進入for循環并遍歷POSTS_DIR中找到的所有文章。

          我們啟動for循環,并打印當前正在處理的post的路徑。如果有什么東西出問題了,這尤其有用。然后我們就知道,哪個文章的轉換失敗了。

          接下來,我們在默認url之后增加一部分。假設我們有一篇標題為“面向初學者的Python”的文章。我們將文章存儲在一個名為python-for-beginners.md,的文件中,因此生成的url將是http://0.0.0.0:5000/posts/python-for-beginners。

          變量url_html存儲的字符串與url相同,只是我們在末尾添加了.html。我們使用此變量定義另一個稱為target_file.的變量。變量指向存儲相應HTML文件的位置。

          最后,我們定義了一個變量md,它表示markdown.Markdown的實例,用于將markdown代碼轉換為HTML。您可能會問自己,為什么我們沒有在for循環之前實例化這個實例,而是在內部實例化。當然,對于我們這里的小例子來說,這沒有什么區別(只是執行時間稍微短一點)。但是,如果使用諸如腳注之類的擴展來使用腳注,則需要為每個帖子實例化一個新實例,因為腳注添加后就不會從此實例中刪除。因此,如果您的第一篇文章使用了一些腳注,那么即使您沒有明確定義它們,所有其他文章也將具有相同的腳注。

          讓我們轉到for循環中的第一個with代碼塊。

          實際上,with代碼塊打開當前post并將其內容讀入變量content。之后調用_md.convert將以markdown方式寫入的內容轉換為HTML。隨后,env環境根據提供的模板BLOG_TEMPLATE_FILE(即layout.html如果你還記得的話)渲染生成的HTML。

          第二個with 代碼塊用于將第一個with 代碼塊中創建的文檔寫入目標文件。

          以下三行代碼從元數據中獲取發布日期(被發布的日期),將其轉換為正確的格式(RFC 2822),并將其分配回文章的元數據。此外,生成的post_dict被添加到all_posts列表中。

          我們現在出了for循環,因此,我們遍歷了posts目錄中找到的所有posts并對其進行了處理。讓我們看看generate_entries函數中剩下的三行代碼。

          我們按日期倒序對文章進行排序,所以首先顯示最新的文章。隨后,我們將文章寫到模板目錄一個新創建的index.html文件中。別把index.html錯認為templates/shared目錄中的那個。templates/shared目錄中的是模板,這個是我們要使用Flask服務的生成的。

          最后我們在函數generate_entries之后添加以下if語句。

          這意味著如果我們通過命令行執行文件,它將調用generate_entries函數。

          太棒了,我們完成了converter.py腳本!讓我們從項目的根目錄運行以下命令來嘗試:

          您應該看到一些正在轉換的文件的路徑。假設您編寫了兩篇文章或使用了GitHub存儲庫中的兩篇文章,那么您應該在templates目錄中找到三個新創建的文件。首先是index.html,它直接位于templates目錄中,其次是templates/posts目錄中的兩個HTML文件,它們對應于markdown文件。

          最后啟動Flask應用程序并轉到http://0.0.0.0:5000。

          總結

          太棒了,你完成了這個系列的第一部分!在本文中,您已經學習了如何利用Markdown包創建自己的Markdown to HTML生成器。您實現了整個管線,它是高度可擴展的,您將在接下來的文章中看到這一點。

          希望你喜歡這篇文章。一定要和你的朋友和同事分享。如果你還沒有,考慮在Twitter上關注我@DahlitzF或者訂閱我的通知,這樣你就不會錯過任何即將發表的文章。保持好奇心,不斷編碼!

          參考文獻

          Bootstrap (http://getbootstrap.com/)

          Primer on Jinja Templating (https://realpython.com/primer-on-jinja-templating/)

          Bootstrap Card (https://getbootstrap.com/docs/4.4/components/card/)

          Python-Markdown Extensions (https://python-markdown.github.io/extensions/)

          Tweet

          英文原文:https://florian-dahlitz.de/blog/build-a-markdown-to-html-conversion-pipeline-using-python
          譯者:阿布銩

          提:

          用python寫了一個簡單的log分析,主要也就是查詢一些key,value出來,后面也可以根據需求增加。查詢出來后,為了好看,搞個html 表格來顯示。

          需要的組件: jinja2 flask 的模板。

          先說下設計思路,主要是練習python代碼玩,高手略過

          模擬scrapy,搞個管線


          每個管線分預處理,分析器,和后處理。預處理的話,可以篩選下數據,分析器提取關鍵信息,然后把結果丟給后處理。html報表就是在后處理生成。

          再搞個manger類,管理很多個管線,雖然現在單路pipeLine就完成了,說不定以后還能擴展呢。



          我們可以定義預處理,比如過濾一些不關注的關鍵字,或者關注一些特定關鍵字的行


          預處理的話,只處理QtiDCT-C關鍵字的日志行。

          然后把經過預處理后的數據丟給分析器

          主要查詢行數據行里面是否有keyword,然后根據分隔符,和結束符來提取內容

          keyword delimiter xxxxxendwith 這樣個模式

          獲取最終結果存儲到字典里面 result[keyword]=xxxx。這里會trim,去掉 \r\n.

          這樣就有了結果集result.最后丟給posthandler 后處理。完成報表輸出。


          后處理主要是用jinja2的模板,然后傳遞參數,生成最終的html文件。

          這里的jinja_template.temple, 內容如下



          有了模板,就可以在渲染模板的時候提供字典,變量,在模板里面顯示。最終完成報表的輸出。


          最終使用


          最終在main 方法中,通過-d參數傳入log所在目錄,然后迭代所有的文件,使用input 把文本文件轉換成行數據的list,丟給管線,最后把管線丟給manager,調用process ,完成txt日志的分析,到最后html的生產。


          主站蜘蛛池模板: 成人免费av一区二区三区| 精品无码人妻一区二区三区品| 鲁丝片一区二区三区免费| 伊人久久一区二区三区无码 | 久久无码人妻精品一区二区三区| 日韩一区精品视频一区二区| 精品国产一区二区三区在线观看 | 国产精品一区二区不卡| 中文字幕在线无码一区二区三区| 日本无卡码免费一区二区三区| 日韩免费一区二区三区在线播放| 国产精品毛片VA一区二区三区| 91一区二区三区| AV无码精品一区二区三区宅噜噜| 日韩毛片一区视频免费| 精品视频一区在线观看| 精品中文字幕一区二区三区四区| 无码人妻一区二区三区av| 久久精品国内一区二区三区| 国产一区二区三区影院| 美女毛片一区二区三区四区| 97av麻豆蜜桃一区二区| 日韩亚洲AV无码一区二区不卡| 91精品一区二区三区在线观看| 精品一区二区三区在线成人| 久久精品道一区二区三区| 国产精品毛片VA一区二区三区| 无码精品国产一区二区三区免费| 3d动漫精品啪啪一区二区免费| 亚洲无圣光一区二区| 精品亚洲A∨无码一区二区三区 | 日韩精品一区在线| 奇米精品视频一区二区三区 | 午夜福利国产一区二区| jazzjazz国产精品一区二区| jazzjazz国产精品一区二区| 国产激情视频一区二区三区| 男女久久久国产一区二区三区| 国产精品高清视亚洲一区二区| 国产成人久久一区二区不卡三区| 在线视频精品一区|