python接收參數
⑴ python flask 怎麼接受參數
GET方式
fromflaskimportFlask,render_template,request
#InitializetheFlaskapplication
app=Flask(__name__)
#Thisisacatchallroute,tocatchanyrequesttheuserdoes
@app.route('/')
defindex():
qs=request.query_string
returnrender_template('index.html',query_string=qs)
if__name__=='__main__':
app.run(
host="0.0.0.0",
port=int("80"),
)
POST方式
fromflaskimportrequest
@app.route('/login',methods=['POST','GET'])
deflogin():
error=None
ifrequest.method=='POST':
ifvalid_login(request.form['username'],
request.form['password']):
returnlog_the_user_in(request.form['username'])
else:
error='Invalisername/password'
#
#
returnrender_template('login.html',error=error)
當然這些官方的開發文檔都有的
⑵ 用python編寫一個函數,接收一個列表參數,函數返回該列表中所有正數之和。最後在主主程序中測試該函數
題主你好,
代碼及測試截圖如下:
希望可以幫到題主, 歡迎追問
⑶ python編寫函數,接收一個參數n生成,n個兩位的隨機整數
import random
number = int(input(':'))
for i in range(number):
print(random.randint(10,99),end=',')
⑷ Python使用Ctypes調用lib,怎麼使用指針類型參數接收輸出參數
本文演示了在python中調用C語言生成的動態庫,返回結構體指針,並進行輸出!
test.c(動態庫源代碼)
// 編譯生成動態庫: gcc -g -fPIC -shared -o libtest.so test.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct StructPointerTest
{
char name[20];
int age;
}StructPointerTest, *StructPointer;
StructPointer test() // 返回結構體指針
{
StructPointer p = (StructPointer)malloc(sizeof(StructPointerTest));
strcpy(p->name, "Joe");
p->age = 20;
return p;
}
編譯:gcc -g -fPIC -shared -o libtest.so test.c
call.py(python調用C語言生成的動態庫):
#!/bin/env python
# coding=UTF-8
from ctypes import *
#python中結構體定義
class StructPointer(Structure):
_fields_ = [("name", c_char * 20), ("age", c_int)]
if __name__ == "__main__":
lib = cdll.LoadLibrary("./libtest.so")
lib.test.restype = POINTER(StructPointer)
p = lib.test()
print "%s: %d" %(p.contents.name, p.contents.age)
最後運行結果:
[zcm@c_py #112]$make clean
rm -f *.o libtest.so
[zcm@c_py #113]$make
gcc -g -fPIC -shared -o libtest.so test.c
[zcm@c_py #114]$./call.py
Joe: 20
[zcm@c_py #115]$
⑸ python怎麼傳參
Python函數參數傳遞機制問題在本質上是調用函數(過程)和被調用函數(過程)在調用發生時進行通信的方法問題。基本的參數傳遞
機制有兩種:值傳遞和引用傳遞。值傳遞(passl-by-value)過程中,被調函數的形式參數作為被調函數的局部變數處理,即在堆棧中開
辟了內存空間以存放由主調函數放進來的實參的值,從而成為了實參的一個副本。值傳遞的特點是被調函數對形式參數的任何操作都是作
為局部變數進行,不會影響主調函數的實參變數的值。(推薦學習:Python視頻教程)
引用傳遞(pass-by-reference)過程中,被調函數的形式參數雖然也作為局部變數在堆棧中開辟了內存空間,但是這時存放的是由主調函
數放進來的實參變數的地址。被調函數對形參的任何操作都被處理成間接定址,即通過堆棧中存放的地址訪問主調函數中的實參變數。正
因為如此,被調函數對形參做的任何操作都影響了主調函數中的實參變數。
⑹ 怎樣才能讓python 腳本像shell命令一樣直接運行並可以接收參數
調用帶參數的腳本,需要首先設置,舉例如下:
test.py按行解釋如下:
- 腳本中有漢字的話,需要聲明文件編碼格式;
- 導入sys模塊,這個模塊是用來獲取參數列表的;
- sys.argv是一個列表,第一個是文件名,之後依次是參數列表;
- 列印輸出,這一步不需要多講;
- 保存到c:usersCDesktop est.py;
調用操作步驟:
- 打開命令行;
- 輸入python 文件名 第一個參數 第二個參數.....(參數之間用空格區分);
- 一定要注意參數個數,要以文件名開始。
⑺ python如何接收子列表為2個浮點數元素的二維列表為參數
python如何接收子列表為2個浮點數元素的二維列表為參數
def df(list1):
print(list1[2])
my_list=[12,34,[2.34,3.14],456,789]
df(my_list)
⑻ python傳入參數的問題
python在定義函數的時候,存在兩種特殊定義,*和**的傳值方式,正是因為這兩種定義,python 函數的傳值,非常靈活,在cpp編程的時候,不支持方法重載,因為沒必要了。。。
在參數前面加個*號,表明這個函數會將這個變數代表的內容,轉換為一個元祖,所以函數可以接收N個元素,這N個元素在函數裡面轉成一個元祖。比如這種
deffun1(*a):#定義
print(a)#1輸出
print(*a)#2輸出
x=[1,2,3]
fun1(x)#1調用
fun1(*x)#2調用
fun(1,2,3)#3調用
因為fun1定義的時候,告訴函數,x可以接受N個對象,這個對象在函數裡面會轉成一個元祖保存,所以在1調用的時候,x在fun1函數裡面會被當成一個元祖,但我們知道,x其實是一個元祖,1調用的時候,就傳了一個對象進去。所以,結果如下
([1,2,3],) #1輸出
[1,2,3] #2輸出
為啥?1輸出,清楚無誤的告訴print(print也是函數,也支持*args方式傳值),你直接把a對象列印出來,a對象是啥?一個包含1個對象的元祖,所以就是(x,)這樣的結果。那2輸出呢?2輸出在調用的時候,在a對象前面已經拆解了元祖,所以,傳給print函數的,是一個對象,就是x了。
同理,在2調用的時候,因為x對象被拆開,所以,func1被傳入多個值,此時的a是一個元素和x相同的元祖。所以2調用的1輸出,就是一個值,就是(1,2,3)。2輸出,因為被拆解了再傳給print,所以,print其實被傳入了多個值,然後將這些值全部列印出來,所以結果是1,2,3.
那3調用呢?其實本質和2調用是一樣的
那雙星號呢?雙星號是拆解key-val格式對的內容,在函數定義的時候,是默認講傳入的產生轉為字典。而規律和上面說的單星號一致。如果用單星號去拆解key-val對象,只會拆解出key。後面的就不多說了。
為啥單引號拆解key-val對象,可以拆出key呢。。。源代碼就這么執行的,為啥當初設計,理由是啥。。。不清楚。。
⑼ python編寫函數,要求接收字元串參數,計算出該字元串中的奇數和偶數的個數並返回。
def test(n):
d={'odd':0,'even':0}
if isinstance(int(n),int):
for x in str(n):
if int(x)%2==0:
d['even']+=1
else:
d['odd']+=1
return d
n=input('請輸入正整數:')
print(test(n))
⑽ 為何Python我的MethodType只能接收2個參數
我用的python3.7也不可以傳入None參數,後來我用python2.7試了一下是可以的。可能是不同版本python的問題(忽略報錯)