#按行读取
for i in range(minrow,maxrow+1):
for j in range(mincol,maxcol+1):
cell=sheet.cell(i,j).value
json_cell = json.dumps(cell)
#print(cell)
params_json = json.loads(json_cell)
print(json_cell)
#print(params_json)
url = 'http://1.1.1.1:9100/shydyy/ewm/CheckTodaySjyxYxjl'
headers = {
'User-Agent':
'Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.0 Mobile/15E148 Safari/604.1',
'Host': '120.195.21.171:9100',
'Origin': '1.1.1.1:9999',
'Referer': '1.1.1.1:9999/',
}
data = {
'TEL': json_cell,
'YGH': '13400863',
}
for i in range(minrow, maxrow + 1):
response = requests.post(url, headers=headers, data=data)
print(data)
print(response.text)
从 excel 表格的第一行读取循环到最后一行并给一个 json 量,用的是 openpyxl 读取 赋值完成之后 我需要根据行数来确定循环多少次 openpyxl 中通过 sheet.max_row 也可实现
每次都需逐行读取 json 替换为 data 中的 TEL 参数并发送一次 POST 请求直到遍历结束
按照上面写每次都只读取最后一个数,各位大佬有什么好的办法吗?
{'msg': '可以正常提交', 'res': 0, 'error': ''}
用r.json获得的,如何提取msg并赋值呢 get对于响应返回不能用 str类的
print("--------------["+str(cell)+"]------------- ")
print(response.status_code)
print(response.json())
print("------------------------------------------ \n")
1
chunhai 2022-09-19 19:25:28 +08:00
没怎么看明白。你为啥先 dumps 后又 loads
|
3
killva4624 2022-09-19 19:34:58 +08:00
没太明白。
读取的总数为 row * col 个,但发送的次数只有 row 次。那每次发哪个值呢? |
4
xianyuyitiao 2022-09-19 19:39:21 +08:00
没太看懂你这个是不是就是完整的 如果就是帖子这样的话肯定是有问题的 你第一个 for 循环完了才走的下面的逻辑 拿到的 json_cell 就是最后一个 正常把 post 请求的逻辑写成一个函数,如果可变的只有 data ,将 data 设置为参数,for 循环拿参数值直接调用函数就好了,只需要 for 循环一次
|
5
RayGZJ OP @killva4624 我只有一列数据 for 循环它的行数就是要遍历的次数
|
6
thinkershare 2022-09-19 19:42:05 +08:00
你这样写的话? i 有什么用呢? 你的 data 需要随着 i 的变化发生变化.
|
7
killva4624 2022-09-19 19:43:29 +08:00
@RayGZJ 遍历数据和 POST 在一个循环里做。
|
8
RayGZJ OP @xianyuyitiao
是这个意思 老大 前面的代码是读取 excel 的代码 简单来说 xlsx 文件只有一列 100 行的手机号数据 我想通过 post 向服务器递交两个参数 tel 及员工号 员工号不变 tel 要随着逐行地区的数据遍历结束 并将服务器的 respone 写入到日志文件 |
9
RayGZJ OP @thinkershare 我不太会写循环 因为是业余爱好者 下午看了三种 python 循环方式 按照上面写的…
|
10
xianyuyitiao 2022-09-19 20:26:06 +08:00
简单的改了下你的 大概就是这么个意思
```python for i in range(minrow,maxrow+1): for j in range(mincol,maxcol+1): cell=sheet.cell(i,j).value #上面用的你原来的逻辑,如果只有一列,列值可以写死,就不用两个 for 循环了 # 不知道哪个库,value 是什么类型,直接转 str 不知道可不可以,需要调试下 tel = str(cell) res_text = post_tel(tel) def post_tel(tel): url = 'http://1.1.1.1:9100/shydyy/ewm/CheckTodaySjyxYxjl' headers = { 'User-Agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.0 Mobile/15E148 Safari/604.1', 'Host': '120.195.21.171:9100', 'Origin': '1.1.1.1:9999', 'Referer': '1.1.1.1:9999/', } data = { 'TEL': tel, 'YGH': '13400863', } response = requests.post(url, headers=headers, data=data) # 这边最好做个是否正确请求的判断 return response.text ``` |
11
xianyuyitiao 2022-09-19 20:26:42 +08:00
@xianyuyitiao 格式没有生效 不知道这个回复怎么调代码格式
|
12
RayGZJ OP @xianyuyitiao
我通过这个方法解决了 ''' for i in range(minrow, maxrow + 1): cell = sheet.cell(i, 1).value #json_cell = json.dumps(cell) print("for "+cell) data = { 'TEL': cell, 'YGH': '13400863', } i=+1 response = requests.post(url, headers=headers, data=data) print(data) print(response.text) ''' |