為了不再被疑似涉嫌低俗,我只能給大家提供這種圖片了,耐得住寂寞才能學有所成!吸引人的東西未必珍貴。
昨天我們學習了《HTML表單元素初識1——零基礎自學網頁制作》(目錄在結尾),大家通過學習對HTML頁面中的表單元素的基本寫法已經非常熟悉了。同時也學會了通過變換<input/>標簽中的type屬性的值為表單賦予不同的功能,例如輸入文本和建立多選表單。期間,對name與value這兩個屬性的作用與特點進行了闡釋。今天我們繼續學習新的表單內容。
建立單選表單:單選表單把<input/>標簽的type屬性修改為"radio"(收音機),為什么單選表單使用"收音機"這個詞呢?其實道理很簡單,收音機調頻旋鈕是對應角度對應相應調頻,不可能一個角度對應兩個調頻,所以選這個就不能選其他的表單中的type屬性使用"radio"這個詞表示,是不是很形象。
示例代碼如下:
<form>
最高學歷:<br>
<input type="radio" name="education" value="highSchool"/>高中
<input type="radio" name="education" value="bachelor"/>本科
<input type="radio" name="education" value="master"/>碩士
<input type="radio" name="education" value="doctor"/>博士
<br>
<input type="submit" value="submit"/>
</form>
因為描寫的是最高學歷,一般人最高學歷只有一個,不可能又是學士又是博士,因此使用單選表單。
向服務器提交時,name叫做"education"(教育),value對應不同層次。
頁面效果如下:
大家可以點點試試,每次只能有一個被選中。如圖:
綜合練習:到這為止,我們把之前零散的代碼拼湊一下看看效果吧!
<!DOCTYPE HTML>
<html>
<head>
<title>表單 </title>
</head>
<body>
<form>
會員名稱:
<input type="text" placeholder="請輸入英文或漢語拼音" name="memberName"/><br>
會員密碼:
<input type="text" placeholder="請輸入英文字母、特殊符號、數字" name="passWord"/><br>
確認密碼:
<input type="text" name="confirmPassWord"/><br>
<input type="submit" value="提交"/><br>
</form>
<hr>
<form>
興趣愛好:
<br>
<input type="checkbox" name="hobby" value="reading"/>讀書
<input type="checkbox" name="hobby" value="film"/>電影
<input type="checkbox" name="hobby" value="painting"/>繪畫
<input type="checkbox" name="hobby" value="music"/>音樂
<br>
最高學歷:<br>
<input type="radio" name="education" value="highSchool"/>高中
<input type="radio" name="education" value="bachelor"/>本科
<input type="radio" name="education" value="master"/>碩士
<input type="radio" name="education" value="doctor"/>博士
<br>
<input type="submit" value="submit"/>
</form>
</body>
</html>
頁面效果如下:
密碼輸入:我們在使用上述表單輸入密碼時發現,密碼時實時顯示在輸入框中,這一點是不安全的,如圖:
如何讓密碼隱藏呢?其實看過上一篇中type屬性列表的小伙伴肯定猜到了,把type從"text"改為password。示例代碼如下:
會員密碼:
<input type="password" placeholder="請輸入英文字母、特殊符號、數字" name="passWord"/><br>
確認密碼:
<input type="password" name="confirmPassWord"/><br>
頁面效果如下:
上傳文件:使用type="file"可以上傳文件!
示例代碼如下:寫在"submit"的上面即可。
<input type="file"/><br><input type="submit" value="submit"/>
頁面效果如下:
點擊"瀏覽"看下效果:
神奇!
使用圖片制作按鈕:將type="image"即可,代碼如下:
<input type="image" src="img/示例圖片/submit.jpg"/><br>
頁面效果如下:用一個src導入圖片即可。
示例圖片:路徑自行設置即可!
為表單設置一個重置按鈕:如果用戶打算重置表單內容后從新填寫,我們可以給他這樣一個按鈕:
<input type="reset" /><br>
頁面如圖所示:
大家要注意的是這個"重置"按鈕的作用范圍僅僅是它所在的<form></form>標簽之間!
舉個例子,如圖:
下面我們點擊"重置"后效果如下:
form1中的內容沒有被清空,"重置"按鈕所在的form2內容被清空了!
type屬性值講解我們到此結束了,hidden值這里先不給大家介紹,以后有機會再細說。
button值以后在JavaScript部分還會細說,這里也先略過。
除了<input/>外,還有其他一些標簽,例如<select>或<textarea>等有趣且實用的標簽,我們明天再學習吧!
今天的內容先到這里。希望大家看完之后可以寫寫代碼進行實操。代碼這種東西即使再簡單,寫過和沒寫過的體會也是不一樣的。這個部分的代碼使用"文本編輯器"就可以實踐。具體操作請詳見《》。
碎片化的知識其實對人并沒有多大作用,但是我們的時間在現代化的生活節奏中被撕地越來越碎,因此我希望大家可以利用碎片時間來學習完整的知識,所以,以短篇的形式,每天20分鐘左右,通過積少成多的辦法為大家提供零基礎頁面制作的教程體系是我的主要目的。希望大家學有所成!
喜歡我的教程的小伙伴請關注我,點贊也會讓我充滿動力!
喜歡的小伙伴請關注和轉發,閱讀中遇到任何問題請給我留言,如有疏漏或錯誤歡迎大家斧正,不勝感激!
HTML序章(學習目的、對象、基本概念)——零基礎自學網頁制作
HTML是什么?——零基礎自學網頁制作
第一個HTML頁面如何寫?——零基礎自學網頁制作
HTML頁面中head標簽有啥用?——零基礎自學網頁制作
初識meta標簽與SEO——零基礎自學網頁制作
HTML中的元素使用方法1——零基礎自學網頁制作
HTML中的元素使用方法2——零基礎自學網頁制作
HTML元素中的屬性1——零基礎自學網頁制作
HTML元素中的屬性2(路徑詳解)——零基礎自學網頁制作
使用HTML添加表格1(基本元素)——零基礎自學網頁制作
使用HTML添加表格2(表格頭部與腳部)——零基礎自學網頁制作
使用HTML添加表格3(間距與顏色)——零基礎自學網頁制作
使用HTML添加表格4(行顏色與表格嵌套)——零基礎自學網頁制作
16進制顏色表示與RGB色彩模型——零基礎自學網頁制作
HTML中的塊級元素與內聯元素——零基礎自學網頁制作
初識HTML中的<div>塊元素——零基礎自學網頁制作
在HTML頁面中嵌入其他頁面的方法——零基礎自學網頁制作
封閉在家學網頁制作!為頁面嵌入PDF文件——零基礎自學網頁制作
HTML表單元素初識1——零基礎自學網頁制作
HTML表單元素初識2——零基礎自學網頁制作
HTML表單3(下拉列表、多行文字輸入)——零基礎自學網頁制作
HTML表單4(form的action、method屬性)——零基礎自學網頁制作
HTML列表制作講解——零基礎自學網頁制作
為HTML頁面添加視頻、音頻的方法——零基礎自學網頁制作
音視頻格式轉換神器與html視頻元素加字幕——零基礎自學網頁制作
HTML中使用<a>標簽實現文本內鏈接——零基礎自學網頁制作
點擊輸入圖片描述(最多18字)
每當測試結束后,測試人員都會輸出一份詳細的測試報告給到領導或者組內人員,那么當我們自動化測試結束后的時候,也可以讓其自動發送測試報告。
這樣領導和組內的成員就能看到自動化測試每次測試的內容了。安靜先介紹下如何通過Python發送郵件,再通過簡單的小例子在自動化測試過程中自動發送報告。
smtplib
smtplib是屬于Python發送郵件的一個庫。其簡單的原理是通過SMTP的方式來實現發送報告的。SMTP(Simple Mail Transfer Protocol)即簡單郵件傳輸協議,它是一組用于由源地址到目的地址傳送郵件的規則,由它來控制信件的中轉方式。
smtplib中對其SMTP的協議進行了一個封裝,其中email是用來支持發送文本、圖片和攜帶附件等功能。
登錄郵箱
發送郵件前肯定需要登錄郵箱了,這里安靜先通過163的郵箱進行介紹,登錄是通過smtplib這個庫進行來完成的。
這里需要先確認發件人的郵箱是否開通了SMTP郵箱權限,可以登錄到163郵箱中,選擇SMTP/IMAP中選擇開啟SMTP服務。勾選后進行連接登錄:
import smtplib
# 創建smtplib服務
smtp=smtplib.SMTP()
# 服務器地址
smtpserver='smtp.163.com'
# 發送賬號
user='XXXXXXXX@163.com'
# 發送密碼
password='xxxxxxx'
# 收件人
receivers='821006052@qq.com'
# 連接服務器
smtp.connect(smtpserver)
# 登錄郵箱賬號
smtp.login(user, password)
(左右滑動查看完整代碼)
郵件發送類型
郵件發送通過Python中的email的庫來實現的,其中email發送郵件可以支持多類型,比如純文本、純圖片、文本加附件等方法,這里安靜會一個個進行介紹。
文本發送
發送郵件肯定包含發送人、收件人、郵件標題、郵件內容等內容,這里email中的Mimetext的方法可以幫助我們實現發送純文本內容。
import smtplib
from email.mime.text import MIMEText
# 創建smtplib服務
smtp=smtplib.SMTP()
# 服務器地址
smtpserver='smtp.163.com'
# 發送賬號
user='xxxxxxx@163.com'
# 發送密碼
password='xxxxxxx'
# 收件人
receivers='821006052@qq.com'
# 郵件標題
subject='自動化測試報告'
# 發送內容 (文本內容,發送格式,編碼格式)
message=MIMEText('這是測試文本內容,自動化測試通過', 'html', 'utf-8')
# 發送地址
message['From']=user
# 接收地址
message['To']=receivers
# 郵件標題
message['subject']=subject
# 連接服務器
smtp.connect(smtpserver)
# 登錄郵箱賬號
smtp.login(user, password)
# 發送賬號信息
smtp.sendmail(user,receivers,message.as_string())
# 關閉
smtp.quit()
(左右滑動查看完整代碼)
通過執行后可以發現,QQ郵箱已經成功的收到了郵件信息。
?
圖片發送
正常發送郵件只需要將郵件全部都復制粘貼到郵件中就行了。但是這里我們通過Python進行發送郵箱,需要用到email中的MIMEimage的模塊了。
這個模塊可以幫助我們將我們需要的圖片內容添加到郵件中,需要我們將本地的圖片導入到html中,通過html中進行發送,如果你通過鏈接的形式發送會失敗,郵件會識別成惡意鏈接,從而進行攔截。這里安靜這接在上面的代碼中進行加入HTML格式,將圖片嵌套在html文本中發送:
import smtplib
from email.mime.text import MIMEText
from email.mime.image import MIMEImage
from email.mime.multipart import MIMEMultipart
# 創建smtplib服務
smtp=smtplib.SMTP()
# 服務器地址
smtpserver='smtp.163.com'
# 發送賬號
user='xxxxxx@163.com'
# 發送密碼
password='xxxxxx'
# 收件人
receivers='821006052@qq.com'
# 郵件標題
subject='自動化測試報告中加入圖片'
# 發送內容 (文本內容,發送格式,編碼格式)
text='''
<html>
<head>自動化測試報告中帶圖片</head>
<body>
<p>
<p><img src="cid:anjing"></p>
<p>
</body>
</html>
'''
message=MIMEMultipart()
body=MIMEText(text, 'html', 'utf-8')
f=open('123.jpg','rb')
mag=MIMEImage(f.read())
f.close()
# 定義圖片ID在HTML中展示
mag.add_header('Content-ID', 'anjing')
# 添加圖片信息
message.attach(mag)
# 添加正文
message.attach(body)
# 發送地址
message['From']=user
# 接收地址
message['To']=receivers
# 郵件標題
message['subject']=subject
# 連接服務器
smtp.connect(smtpserver)
# 登錄郵箱賬號
smtp.login(user, password)
# 發送賬號信息
smtp.sendmail(user,receivers,message.as_string())
# 關閉
smtp.quit()
(左右滑動查看完整代碼)
通過執行上面的代碼可以看到QQ郵箱,已經接收到了郵件信息,打開郵箱清楚的看到,圖片已經在文本中添加了。
?
附件發送
發送郵件需要帶附件的情況下,我們可以使用email庫中的MIMEMUltipart模塊。
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
# 創建smtplib服務
smtp=smtplib.SMTP()
# 服務器地址
smtpserver='smtp.163.com'
# 發送賬號
user='xxxxxx@163.com'
# 發送密碼
password='xxxxxx'
# 收件人
receivers='821006052@qq.com'
# 郵件標題
subject='自動化測試報告中附件'
message=MIMEMultipart()
body=MIMEText('自動化測試報告攜帶附件內容', 'html', 'utf-8')
# 添加正文
message.attach(body)
att=MIMEText(open('123.jpg', 'rb').read(), 'base64', 'utf-8')
att["Content-Type"]='application/octet-stream' # 死格式
# filename 表示附件的名稱
att["Content-Disposition"]='attachment; filename="fujian.jpg"'
# 郵件中添加附件
message.attach(att)
# 發送地址
message['From']=user
# 接收地址
message['To']=receivers
# 郵件標題
message['subject']=subject
# 連接服務器
smtp.connect(smtpserver)
# 登錄郵箱賬號
smtp.login(user, password)
# 發送賬號信息
smtp.sendmail(user,receivers,message.as_string())
# 關閉
smtp.quit()
(左右滑動查看完整代碼)
通過執行代碼清楚的看到郵件中已經攜帶了附件內容,并且成功發送了。
zmail郵件
一些測試同學看到上面這么多代碼估計腦袋就大,安靜在給大家介紹一種簡單方便的發送郵件庫zmail,這個庫的目的就是為了方便發送郵件。
但是要注意zmail這個庫目前只支持Python3不支持Python2,想必都2021年了,沒人再用Python2了吧。
安裝:
pip install zmail
(左右滑動查看完整代碼)
文本發送
繼續從文本發送,先創建一個zmail服務,將其發件人郵箱賬號以及郵箱授權碼(163設置中的SMTP打開)進行連接通過zmail服務連接。編輯文本進行發送:
import zmail
# 發件人
username='xxxxxx@163.com'
# 授權碼密碼
password='xxxxxx'
# 創建zmail服務
server=zmail.server(username,password)
# 郵件主題
body={
'subject': "自動化測試報告", # 郵件標題
"content_text": '這是郵件的文本內容,自動化測試結果', # 郵件文本
}
# 收件人
receivers='821006052@qq.com'
# 發送郵件
server.send_mail(receivers,body)
(左右滑動查看完整代碼)
通過代碼就可以看出來很清楚的就講郵件內容展現出來,執行代碼,成功的收到郵件信息。
?
圖片發送
同樣文本發送完成后,繼續來我們的圖片發送。這里可以通過圖片的base64的格式加入到html的代碼中,然后放入到文本中進行發送。
import zmail
# 發件人
username='xxxxx@163.com'
# 授權碼密碼
password='xxxxxx'
# 創建zmail服務
server=zmail.server(username,password)
html='''
<p> 這是郵件的文本內容,自動化測試結果 </p>
<img src=''/>
'''
# 郵件主題
body={
'subject': "自動化測試報告添加圖片", # 郵件標題
"content_html": html, # html格式
}
# 收件人
receivers='821006052@qq.com'
# 發送郵件
server.send_mail(receivers,body)
(左右滑動查看完整代碼)
通過代碼執行后可以發現,郵件成功的收到了并且圖片和文本都存在郵件中:
附件發送
通過上面的兩個例子這里應該很清楚的就能知道了,我們只需要將附件信息直接寫在我們的body文本中就行了。
import zmail
# 發件人
username='xxxxx@163.com'
# 授權碼密碼
password='xxxxx'
# 創建zmail服務
server=zmail.server(username,password)
html='''
<p> 這個郵件中攜帶附件,自動化測試結果 </p>
<img src=''/>
'''
# 郵件主題
body={
'subject': "自動化測試報告添加附件", # 郵件標題
"content_html": html, # html格式
"attachments": "123.jpg" # 附件
}
# 收件人
receivers='821006052@qq.com'
# 發送郵件
server.send_mail(receivers,body)
(左右滑動查看完整代碼)
通過制定代碼后發現,郵件已經成功發送且攜帶了附件內容。
?
yagmail
yagmail也是屬于Python發送郵件的一個庫,這種庫相比前面兩種依舊做了很大的簡介,使用更加方便,因為屬于Python的第三方庫,我們安裝。
安裝:
pip install yagmail
(左右滑動查看完整代碼)
發送文本
這里一樣先將yagmail創建一個服務對象,通過將發件人的賬號,授權碼進行連接登錄。
import yagmail
# 發件人
username='xxxxxx@163.com'
# 授權碼密碼
password='xxxxxx'
# 創建yagmail服務,需要加上服務器地址
server=yagmail.SMTP(username,password, host='smtp.163.com')
# 收件人
receivers='821006052@qq.com'
text='這是測試報告內容' # 報告內容
title='自動化測試報告' # 郵件標題
server.send(contents=text,to=receivers,subject=title)
(左右滑動查看完整代碼)
通過發現yagmail的代碼比zmail的代碼更加簡潔了一些,但是整體內容是差不多的。執行代碼,發現我們已經將其報告發送成功了。
?
圖片發送
yagmail中攜帶了發送圖片的方法,直接將圖片路徑方進入就可以了,其中這里需要使用yagmai.inline的方法將圖片添加到正文中:
import yagmail
# 發件人
username='xxxx@163.com'
# 授權碼密碼
password='xxxxx'
# 創建yagmail服務,需要加上服務器地址
server=yagmail.SMTP(username,password, host='smtp.163.com')
# 收件人
receivers='821006052@qq.com'
text='這是測試報告內容加上圖片顯示內容' # 報告內容
title='自動化測試報告攜帶圖片' # 郵件標題
img=yagmail.inline('123.jpg') # 圖片地址
server.send(contents=text,to=receivers,subject=title,attachments=img)
(左右滑動查看完整代碼)
執行代碼發現,我們已經成功的將圖片添加到了郵件中:
?
附件發送
附件形式yagmail中也提到了單獨的方法,通過attachments的方法來添加附件文件。
import yagmail
# 發件人
username='xxxxxx@163.com'
# 授權碼密碼
password='xxxxx'
# 創建yagmail服務,需要加上服務器地址
server=yagmail.SMTP(username,password, host='smtp.163.com')
# 收件人
receivers='821006052@qq.com'
text='這是測試報告內容加上附件內容' # 報告內容
title='自動化測試報告攜帶附件' # 郵件標題
fujian='123.jpg' # 附件
server.send(contents=text,to=receivers,subject=title, attachments=fujian)
(左右滑動查看完整代碼)
通過執行代碼發現,我們已經成功的將郵件攜帶附件發送成功了。
?
實戰演示
前面已經將Python幾種發送報告的庫都做了一個簡單的介紹,安靜在這里在給大家通過UnitTest生成一份測試報告,然后在通過郵件的形式發送出去來進行演示,方便大家記憶。
古話說,好記性不如爛筆頭,腦子笨,咱多寫幾遍,就記住了。
UnitTest生成報告并發送報告
安靜隨便寫幾個測試用例,然后通過HTMLTestRunner的方式生成測試報告。
import unittest
import HTMLTestRunner
class Test(unittest.TestCase):
def test_01(self):
print('測試用例1')
def test_02(self):
print('測試用例2')
def test_03(self):
print('測試用例3')
if __name__=='__main__':
# 測試報告地址
fp=open('result.html', "wb")
# 報告詳情
runner=HTMLTestRunner.HTMLTestRunner(stream=fp,
title=u'自動化測試報告,測試結果如下:',
description=u'用例執行情況:')
# 實例化
testunit=unittest.TestSuite()
# 加載用例
testunit.addTests(unittest.TestLoader().loadTestsFromTestCase(Test))
# 執行用例
runner.run(testunit)
# 關閉報告
fp.close()
(左右滑動查看完整代碼)
通過執行代碼發現測試報告已經生成了,接下來我們需要通過將其測試報告內容添加到郵件中然后在進行發送。
郵件加入測試報告結果
上面已經通過UnitTest單元測試框架生成了測試報告,接下來就是需要我們通過郵件庫來進行發送了,安靜這里選擇了yagmail,別問為什么,想用哪個就用了。
import yagmail
# 發件人
username='xxxxxx@163.com'
# 授權碼密碼
password='xxxxxx'
# 創建yagmail服務,需要加上服務器地址
server=yagmail.SMTP(username,password, host='smtp.163.com')
# 收件人
receivers='821006052@qq.com'
with open('result.html', 'rb')as f:
text=f.read()
title='自動化測試結果' # 郵件標題
fujian=r'E:\web\result.html' # 附件
server.send(contents=text.decode('utf-8'), to=receivers, subject=title,attachments=fujian)
(左右滑動查看完整代碼)
通過執行代碼后發現測試報告內容已經成功發送了(這里有個問題就是排版可能發生了一些改變),但是整體的報告內容以及附件全部都發送了。
?
總結
安靜分別簡單的介紹了Python發送郵件的方法,其中有簡單的,也有復雜操作的,但是據圖使用哪種就要看個人的喜好了。
nceIO是OnceDoc企業私有內容(網盤)管理系統的底層Web框架,它可以實現模板文件、靜態文件的全緩存,運行起來完全不需要I/O操作,并且支持客戶端緩存優化,GZIP壓縮等(只壓縮一次),擁有非常好的性能,為您節約服務器成本。它的模塊化功能,可以讓你的Web進行分布式存儲,在一個擴展包里即可包含前端、后端和數據庫定義,只需通過添加/刪除目錄的方式就可實現功能刪減,實現真正的模塊化擴展。目前OnceIO已經開源,這里是介紹如何使用的一系列文章。
OnceIO 提供將一個網頁文件嵌套在另一個網頁文件中的機制。文件嵌套與模板引擎無關,語法固定為 <!--#include="path"-->
,其中 path 為文件相對路徑,引號必須為雙引號,中間不能有空格。以 index.html 的代碼為例:
<html>
<body>
<!--#include="header.html"-->
<div>
Main content
</div>
<!--#include="footer.html"-->
</body>
</html>
這段代碼將 header.html 和 footer.html 兩個網頁文件嵌套在 index.html 中。用戶訪問 index.html 時,header.html 和 footer.html 也會被同時加載,其中的元素將顯示在網頁的相應位置。
header.html 代碼為:
<div>
<center>
Header
</center>
<hr>
</div>
footer.html 代碼為:
<div class='footer'>
<hr>
<center>
Footer
</center>
</div>
index.html 顯示效果為:
嵌套的層數理論上是沒有限制的,被嵌套網頁也能嵌套其它網頁,但互相循環嵌套可能會造成問題。例如,如果在 header.html 中嵌套 index.html,而index.html又嵌套了header,則index.html 顯示效果為:
使用網頁嵌套時,服務器需要時間加載所有被嵌套網頁,因此用戶第一次訪問時瀏覽器可能無法顯示被嵌套網頁的內容,刷新后才能顯示完整網頁,OnceIO 內置的 preload 方法能解決這個問題。對當前目錄下的 html 后綴的文件使用 preload 的示例代碼如下:
app.preload('.', '.html')
preload 的第一個參數是相對路徑,示例中的 '.' 代表 home 路徑,home 是 OnceIO 應用程序的一個屬性,它的值可以在定義應用程序時設置,默認值為 './',即當前目錄;第二個參數是文件類型,示例中的 '.html' 代表 html 后綴的網頁文件。
使用 preload 后,服務器會提前加載網頁文件并將其緩存在服務器內存中,用戶第一次訪問時無需刷新即可看到完整網頁。
OnceIO項目: https://github.com/OnceDoc/onceio
*請認真填寫需求信息,我們會在24小時內與您取得聯系。