python批量创建变量并赋值操作


Posted in Python onJune 03, 2021

一,简单的情况:

核心是exec函数,exec函数可以执行我们输入的代码字符串。exec函数的简单例子:

exec ('print "hello world"')
hello world

可以很清晰的看到,我们给exec传入一个字符串'print "hello world"',exec是执行字符串里面的代码print "hello world"。根据这个特性,我们可以用占位符实现我们对变量的定义,如:

exec ("temp%s=1"%1)

这段代码的意思是,让exec执行temp1=1。字符串里面的%s由‘1'代替了。我们在外面再套一个循环就可以实现对多个变量的定义了。

for i in range(10):
    exec ("temp%s=1"%i)

在这里,通过一个循环来生成10个变量,i的变化从0到9。用变量i替代%s,所以在每次循环里面,分别给temp0,temp1赋值。

执行结果:

python批量创建变量并赋值操作

如果想要替换多个占位符,可以这样写:

exec ("temp%s=%d"%(i,i))

在这里,分别以字符串、整数形式替换占位符,执行结果:

temp1=1

又如:

df_vars = [ 'df_%s_head' %i for i in range(0,10)]

df_vars:

['df_0_head',
 'df_1_head',
 'df_2_head',
 'df_3_head',
 'df_4_head',
 'df_5_head',
 'df_6_head',
 'df_7_head',
 'df_8_head',
 'df_9_head']

再比如:

for i in range(8):
     exec('v' + str(i) + ' = ' + str(i))
     print('v' + str(i) + ':', eval('v' + str(i)))

输出结果:

python批量创建变量并赋值操作

例子:

在python中,为了生成顺序的变量名并将其赋值,如

a_1 = []
a_2 = []
a_3 = []
.....
a_100 = []

可以利用将字符串转换成变量的函数exec

for i in range(1,100):
    b = 'a_' + str(i)
    exec(b + '= %r' % [])

二,略微复杂的命名

提取出:

D:/MyData/Excel/input/MarketHoliday_2018.xls

D:/MyData/Excel/input/MarketHoliday_2019.xls

。。。

D:/MyData/Excel/input/MarketHoliday_2023.xls

year = [2018,2019,2020,2021,2022,2023] 
file_path = 'D:/MyData/Excel/input/MarketHoliday_'  #注意:这里一定要用单引号

要先把year转为dict, 以便运用在For循环中,这里我用pandas转换

import pandas as pd
year = pd.Series(year)
year_dict = year.to_dict()

得到:

python批量创建变量并赋值操作

for i in year_dict:
    exec('Var_'+str(year_dict[i])+'='+'"'+(file_path + str(year_dict[i])+'.xls'+'"'))
    print('Var_'+str(year_dict[i])+':',eval('Var_'+str(year_dict[i])))

最终结果:

python批量创建变量并赋值操作

python 动态生成变量名及赋值

今晚在处理数据的时候偶然遇到一个命名上的难点,但是为了实现自动处理坚决不动手一条一条输入参数,我非要把它解决了,问题是这样的

首先我想要调用一个方法,然后输入的变量可以是字符串,但是,当你直接把字符串输入就不行了

这里献上代码:

t=['42342lh','234']
s='fgdfhdfhdfh'
exec(s+'=%s'%'t[0]')
print(fgdfhdfhdfh)
for i in range(2):
    m=f'names{i}'
    exec(m+'=%s'%'t[i]')
print(names1)

可以看出来m可以自己按规律这sing,同时也可以规律读取,最后每个m就成了变量。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
布同自制Python函数帮助查询小工具
Mar 13 Python
用python + hadoop streaming 分布式编程(一) -- 原理介绍,样例程序与本地调试
Jul 14 Python
Python的内存泄漏及gc模块的使用分析
Jul 16 Python
python读取json文件并将数据插入到mongodb的方法
Mar 23 Python
python 中if else 语句的作用及示例代码
Mar 05 Python
pandas.dataframe中根据条件获取元素所在的位置方法(索引)
Jun 07 Python
python3.6.3转化为win-exe文件发布的方法
Oct 31 Python
python实现小世界网络生成
Nov 21 Python
python 贪心算法的实现
Sep 18 Python
PyQt5通过信号实现MVC的示例
Feb 06 Python
让文件路径提取变得更简单的Python Path库
May 27 Python
浅析python中特殊文件和特殊函数
Feb 24 Python
详解运行Python的神器Jupyter Notebook
Jun 03 #Python
python中如何对多变量连续赋值
Python连续赋值需要注意的一些问题
Jun 03 #Python
pytorch fine-tune 预训练的模型操作
Jun 03 #Python
Python实现byte转integer
Jun 03 #Python
Python数据分析之绘图和可视化详解
Python数据分析之pandas读取数据
Jun 02 #Python
You might like
德生H-501的评价与改造
2021/03/02 无线电
PHP中开发XML应用程序之基础篇 添加节点 删除节点 查询节点 查询节
2010/07/09 PHP
服务器上配置PHP运行环境教程
2015/02/12 PHP
CodeIgniter常用知识点小结
2016/05/26 PHP
PHP MYSQL简易交互式站点开发
2016/12/27 PHP
一文掌握PHP Xdebug 本地与远程调试(小结)
2019/04/23 PHP
出现“不能执行已释放的Script代码”错误的原因及解决办法
2007/08/29 Javascript
纯js实现背景图片切换效果代码
2010/11/14 Javascript
改进版通过Json对象实现深复制的方法
2012/10/24 Javascript
html向js方法传递参数具体实现
2013/08/08 Javascript
jQuery Ajax异步处理Json数据详解
2013/11/05 Javascript
js简单抽奖代码
2015/01/16 Javascript
JavaScript实现信用卡校验方法
2015/04/07 Javascript
全面解析Bootstrap手风琴效果
2020/04/17 Javascript
jQuery实现TAB选项卡切换特效简单演示
2016/03/04 Javascript
基于js实现二级下拉联动
2016/12/17 Javascript
Node.js使用orm2进行update操作时关联字段无法修改的解决方法
2017/06/13 Javascript
MUI顶部选项卡的用法(tab-top-webview-main)详解
2017/10/08 Javascript
vuejs+element UI table表格中实现禁用部分复选框的方法
2019/09/20 Javascript
[01:04:29]DOTA2-DPC中国联赛 正赛 Phoenix vs XG BO3 第二场 1月31日
2021/03/11 DOTA
wxpython 学习笔记 第一天
2009/03/16 Python
在Python中使用SimpleParse模块进行解析的教程
2015/04/11 Python
PyCharm2018 安装及破解方法实现步骤
2019/09/09 Python
Python列表删除元素del、pop()和remove()的区别小结
2019/09/11 Python
基于python检查矩阵计算结果
2020/05/21 Python
python实现画图工具
2020/08/27 Python
利用Python如何画一颗心、小人发射爱心
2021/02/21 Python
python利用后缀表达式实现计算器功能
2021/02/22 Python
css3实现可滑动跳转的分页插件示例
2014/05/08 HTML / CSS
ECCO英国官网:丹麦鞋履品牌
2019/09/03 全球购物
将"引用"作为函数返回值类型的格式、好处和需要遵守的规则
2016/02/09 面试题
建筑公司员工自我鉴定
2014/04/08 职场文书
《赠汪伦》教学反思
2014/04/12 职场文书
2014年小学教师工作总结
2014/11/10 职场文书
实习协议书
2015/01/27 职场文书
python基础之错误和异常处理
2021/10/24 Python