mock接口開發,excel(讀,寫,修改)

mock接口開發

首先需要安裝? Flask 模塊? :pip install flask

然后引用? ?from flask import request #想獲取到請求參數的話,就得用這個

lanxia =?flask.Flask(__name__) #把這個python文件當做一個web服務

@lanxia.server('/login',[ ' post ' , ' get ' ] )#第一個參數是路徑,第二個參數是請求方式;如果不填寫默認為get方式

def web():#函數和上一行必須連著,不能有空行

? ? username = request.values.get('n')??#get請求獲取值的方式,‘n’代表入參時候的key
????pwd = request.values.get('p')#get請求獲取值的方式,‘p’代表入參時候的key

????json_user_id = request.json.get('a')?#post請求方式(json串)獲取值的方式,‘a’代表入參時候的key
????json_sign = request.json.get('b')#post請求方式(json串)獲取值的方式,‘a’代表入參時候的key

lanxia.run(port=8003,debug=Truehost =’127.0.0.1’)#運行這個服務,port端口號(不能被占用),debug=Ture代表開啟每次修改代碼后自動重啟服務,host代表他人如果想要訪問這個接口地址時候的ip

所以值返回來的格式都是字符串類型

?

?flask.request.headers.get('傳的header的key')#接口獲取header的方法

獲取header方法:request.headers


?flask.request.cookies.get('傳的cookie的key')#接口獲取key的方法

獲取cookie方法:request.cookies

?

file = {“ker”:open(‘haha.py’)}#傳的value是文件句柄

?flask.request.files.get('傳的files的key')#接口獲取key的方法

獲取文件方法:自動上傳到了設置好的路徑

?

下載文件

接口代碼

@app.route('/upload',methods=['post'])

def?upload():
????#上傳文件接口
????f?=?request.files.get('file_name',None)
????if?f:
????????t?=?time.strftime('%Y%m%d%H%M%S')#獲取當前時間
????????new_file_name?=?t+f.filename#給文件重命名,防止有重復文件覆蓋
????????f.save(new_file_name)#保存文件
????????return?jsonify({"code":"ok"})
????else:
????????return?jsonify({"msg":"請上傳文件!"})
app.run(debug=True,port=8888)#啟動這個web服務

?

?

寫入Excel

需要安裝xlwt模塊:pip install xlwt

import xlwt? ?
book ?= xlwt.Workbook()#創建一個excel??
sheet = book.add_sheet('lanxia')#添加一個sheet
title = ['姓名','班級','住址','手機號']
data = [
????['','巨蟹座','中南海',110],
????['水瓶座','巨蟹座','紫禁城',119]
]
i=0#控制列
for j in title:
????#j是每次循環title的內容
????sheet.write(0,i,j)#0是行不變,i是列,每次循環的內容
????i+=1#每次循環的時候列都加1
line=1#控制寫的行
for d in data:#外層循環是控制行數的
????row = 0#代表的列,列每次都變
????for dd in d:#控制列的
????????sheet.write(line,row,dd)#行,列,內容
????????row+=1#列每次都要加一
????line+=1
book.save('skkk8.xls')#后綴只能用xls,要不然打不開

?

讀取Excel

需要安裝xlwd模塊:pip install xlrd

book = xlrd.open_workbook('D:\Documents\Tencent Files\837221976\FileRecv\測試用例.xlsx')
sheet = book.sheet_by_name('Sheet1')

rows = sheet.nrows#sheet頁里面的行數
clos = sheet.ncols#sheet頁里面的列數
print(sheet.cell(1,1).value)#通過指定行和列去獲取到單元格里面的內容
row_data = sheet.row_values(1)#獲取第一行的內容
for i in range(rows):
????print(sheet.row_values(i))#獲取第幾行的數據

?

修改excel

?

需要安裝xlutils模塊:pip install?xlutils

from xlutils.copy import copy#拷貝excel模塊方法
import xlrd#修改時需要使用讀
import os
#1、打一要修改的excel
#2、再打開另一個excel
#3、把第一個excel里面修改東西寫到第二個里頭
#4、把原來的excel刪掉,新的excel名改成原來的名字
book = xlrd.open_workbook('stu.xls')
#復制一個excel
new_book = copy(book)#復制了一份原來的excel
#通過獲取到新的excel里面的sheet
sheet = new_book.get_sheet(0)#獲取到第一個sheet
sheet.write(6, 0, 'Dandan Sun')#寫入excel,第一個值是行,第二個值是列
new_book.save('stu_new.xls')#保存新的excel,保存excel必須使用后綴名是.xls的,不是能是.xlsx
os.remove('stu.xls')#刪除舊的文檔
os.rename('stu_new.xls','stu.xls')#重命名(“舊名字“,”最新命名的名字”)

?

轉載于:https://www.cnblogs.com/lanxia/p/7845210.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/370596.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/370596.shtml
英文地址,請注明出處:http://en.pswp.cn/news/370596.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

web前端學習之ruby標記和rt/rp標記

ruby 標記定義ruby注釋(中文注音或字符)。ruby標記與rt標記一同使用。ruby標記由一個或多個字符(需要一個解釋/發音)和一個提供該信息的rt 標記組成,還包括可選的rp標記,定義當瀏覽器不支持ruby 標記時顯示…

mysql 5.7 udf http_mysql下mysql-udf-http效率測試小記

看到張宴的博客上關于"http/rest客戶端的文章",怎樣安裝啥的直接都跳過,下面直接進入測試階段,測試環境:虛擬機復制代碼 代碼如下:[rootlocalhost ~]# uname -aLinux sunss 2.6.18-128.el5 #1 SMP Wed Jan 21 10:44:23 …

作為一名程序員,聊聊我們的現狀和未來

前言:互聯網這個高速發展的新興行業,注定是敢想敢干敢創新,耐勞耐操耐折騰年輕人的天下? 我們所在的互聯網行業,不斷地有新的公司冒出,有新的商業模式成形,有新的產品形態影響著大家的生活日常&…

適用于孩子,父母和祖父母的JBoss HornetQ –第1章

現在與HornetQ合作已經快4年了,我認為是時候分享我到目前為止所學知識的一部分了。 這篇文章的主要目的不是重寫官方文檔 ,而是以簡單的方式闡明我們在PaddyPower中最常用的概念。 什么是HornetQ HornetQ是JMS實現。 JMS是一種面向消息的中間件API&am…

riot.js教程【四】Mixins、HTML內嵌表達式

前文回顧riot.js教程【三】訪問DOM元素、使用jquery、mount輸入參數、riotjs標簽的生命周期;riot.js教程【二】組件撰寫準則、預處理器、標簽樣式和裝配方法;riot.js教程【一】簡介; 共享Mixins 混合開發可以使你很好的復用代碼,如…

移動端判斷手機橫豎屏狀態

禁用用戶自動縮放功能&#xff1a; <meta name"viewport" content"widthdevice-width, initial-scale1.0, maximum-scale1.0, user-scalable0"> 判斷橫豎屏狀態有兩種方法&#xff1a;css判斷、js判斷 (一)、css判斷橫屏還是豎屏 1、寫在同一個css文…

ubuntu dhcp ping 不通 自己_??2、DHCP安裝和配置

DHCP動態主機設置協議&#xff0c;是一個局域網的網絡協議&#xff0c;使用UDP協議工作&#xff0c;可以快速分配IP地址&#xff0c;解決內網IP不足、手動配置IP造成IP沖突以及內網機器多手工配置比較麻煩的問題。1.把win2008和win2003設置同一網段&#xff0c;網絡適配器—配置…

python秒數變日期_將pandas日期列轉換為已用秒數

新答案 將文本轉換為Timedeltadf[Origin Time(Local)] pd.to_timedelta(df[Origin Time(Local)]) df[Seconds] df[Origin Time(Local)].dt.total_seconds() 舊答案 考慮數據幀dfdf pd.DataFrame(dict(Datepd.date_range(2017-03-01, 2017-03-02, freq2H))) Date 0 2017-03-0…

mysql用一個表更新另一個表的方法

Solution 1: 修改1列(navicate可行) update student s, city c set s.city_name c.name where s.city_code c.code; Solution 2: 修改多個列 update a, b set a.titleb.title, a.nameb.name where a.idb.id Solution 3: 采用子查詢(navicate不可行) update student s set…

選擇您的Java EE 6應用服務器

我被問到的第一個問題是&#xff1a;“我們應該使用哪個Java EE應用服務器&#xff1f;”。 隨著Java EE 6的日益普及&#xff0c;新的兼容應用程序服務器獲得了認證。 當前的官方兼容性和認證矩陣列出了針對完全配置文件&#xff0c;Web配置文件或兩者認證的12種不同產品。 如…

串的基本計算

#include<stdio.h> #include<stdlib.h> //typedef int Status; #define Max 20 #define OK 1 #define ERROR 0 #define OVERLOE -2 typedef struct//堆分配表示串 { char *ch; int length; }HString; // int CreatHString(HString &H)//構造字符串 { H.length …

HTML表格屬性及簡單實例

這里主要總結記錄下表格的一些屬性和簡單的樣式&#xff0c;方便以后不時之需。 1、<table> 用來定義HTML的表格&#xff0c;具有本地屬性 border 表示邊框&#xff0c;border屬性的值必須為1或空字符串("")。該屬性不會控制邊框的樣式&#xff0c;而是由CSS來…

怎么查看MySQL 源碼編譯了什么_Mysql 源碼編譯教程貼

題外話:這是一篇教程貼,不僅學的是mysql的編譯,還是一些編譯的知識.我也是一個菜鳥,寫一些感悟和心得,有什么問題可以批評指正,謝謝!如果只是為了安裝請移到我的另一篇安裝貼: Mysql安裝貼環境:OS: CentOS 6.6x64 minimysql: mysql-5.6.251. mysql 下載:http://dev.mysql.com/d…

linux mysql啟動_MySQL 安裝(二)

MySQL 安裝所有平臺的Mysql下載地址為&#xff1a;MySQL 下載 . 挑選你需要的 MySQL Community Server 版本及對應的平臺。Linux/UNIX上安裝MySQLLinux平臺上推薦使用RPM包來安裝MySQL&#xff0c;MySQL AB提供了以下RPM包的下載地址&#xff1a;MySQL - MySQL服務器。你需要該…

0524駝峰命名法,模態對話框

模態對話框 window.showModalDialog("url"&#xff0c;"向目標對話框傳的值"&#xff0c;"窗口特征參數") 打開模態對話框 模態對話框必須關掉才能對后端操作。 模塊對話框和窗口的區別是永遠置頂。 特征參數&#xff1a;用分號隔開&#xff0c;…

誰在偷你的記憶? 應用服務器版

您創建了一個了不起的應用程序。 您將其投入生產。 您會發現您沒有足夠的可用內存。 即使您的所有測量結果&#xff08;可能是借助我們的小型公用事業公司進行的測量 &#xff09;都表明您應該還不錯。 我們計劃發布一系列博客文章&#xff0c;研究堆消失的位置&#xff0c;并…

遺忘的html標簽

1 <span>x</span><sup>2</sup><span> y10</span> 2 <br> 3 <span>H</span><sub>2</sub><span>O</span> <sup> 標簽可定義上標文本。 包含在 <sup> 標簽和其結束標簽 …

Android四大組件之BroadcastReceiver

什么是BroadcastReceiver? BroadcastReceiver(廣播接收器)&#xff0c;顧名思義&#xff0c;是用來接收廣播的。Android內部實現了一套廣播通信機制&#xff0c;即在某個應用或某個組件注冊廣播接收器&#xff0c;接收特定類型的廣播。當別的應用或組件發送該類型的廣播時&…

mysql數據庫索引頁號為什么從3開始_MySQL數據庫快問快答

原標題&#xff1a;MySQL數據庫快問快答前言今天樓主給大家列一下關于數據庫幾個常見問題的要點&#xff0c;如果大家對其中的問題感興趣&#xff0c;可以自行擴展研究。1. UNION ALL 與 UNION 的區別UNION和UNION ALL關鍵字都是將兩個結果集合并為一個。UNION在進行表鏈接后會…

通過簡單的Spring方面擺脫null參數

什么是世界上最令人討厭的&#xff0c;同時也是最受歡迎的例外&#xff1f; 我敢打賭這是NullPointerException。 NullPointerException可以表示任何東西&#xff0c;從簡單的“ ups&#xff0c;我認為不能為空”到數小時和數天的第三方庫調試&#xff08;我敢于嘗試使用Doze…