博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python 如何生成矩阵
阅读量:4171 次
发布时间:2019-05-26

本文共 830 字,大约阅读时间需要 2 分钟。

本文介绍Python2中的生成矩阵的方法
1》借助于内置函数range()和for循环
def makeMatrix(row_num,column_num,start=0,step=1):
    matrix=[]
    row=[]
    for i in range(row_num):
        for j in range(column_num):
            row.append(start)
            start+=step
        matrix.append(row)
        row=[]
    return matrix
M=makeMatrix(3,4) # 起始位置和步长取默认值
print M
运行结果,如下:
[[0, 1, 2, 3], [4, 5, 6, 7], [8, 9, 10, 11]]
M=makeMatrix(3,4,10,2) # 指定起始位置和步长
print M
运行结果如下:
[[10, 12, 14, 16], [18, 20, 22, 24], [26, 28, 30, 32]]
2》由一个元组(或列表)生成矩阵
def tuple2Matrix(t,row_num,column_num):
    row=[]
    row_count=0
    count=0
    for x in t:
        row.append(x)
        count+=1
        if count%column_num==0: #判断是否填满了一行
            yield row
            row=[]
            row_count+=1
        if row_count==row_num: #达到要求的行数,就结束循环
            break
matrix=[]
t=(1,2,3,4,5,6,7,8,9,10,11,12,13,14)
for r in tuple2Matrix(t,2,4):
    matrix.append(r)
print matrix
运行结果如下:

[[1, 2, 3, 4], [5, 6, 7, 8]]

关于Python中 yield 的使用,参考:

转载地址:http://vdyai.baihongyu.com/

你可能感兴趣的文章
C&C远控工具:Ares
查看>>
窃密团伙瞄准企业机密信息,备用病毒超60个
查看>>
勒索软件的“中流砥柱”:深入分析GandCrab新型Evasive感染链
查看>>
FIN7 2.0归来:“借尸还魂”的可疑组织们
查看>>
CVE-2019-5018:Sqlite3 远程代码执行漏洞
查看>>
HITB | 360议题分享:卫星可欺骗 地震警报可伪造
查看>>
公有云容器安全
查看>>
为逃避检测而取消持久性:KPOT v2.0信息窃取恶意软件分析
查看>>
《Lateral Movement — SCM and DLL Hijacking Primer》的利用扩展
查看>>
为逃避检测而取消持久性:KPOT v2.0信息窃取恶意软件分析
查看>>
ScarCruft APT组织开发针对蓝牙的恶意软件
查看>>
抢地盘?两大黑客组织就Linux服务器展开激烈角逐
查看>>
Windows Hello认证推进无密码认证
查看>>
发公告说被关了?认真你就输了
查看>>
CVE-2019-0708漏洞影响面分析及采用多种规则的检测方法
查看>>
拿走不谢!固件逆向分析过程中的工具和技巧(上)
查看>>
整理网络安全措施的5个小技巧
查看>>
原来Java反序列化远程执行漏洞这么简单
查看>>
移动应用安全基础篇——解密iOS加密数据
查看>>
针对国内IP发起攻击的DDoS样本分析
查看>>