gurobi与python应用之数组生成,转换,修改,存储及读取

2023-12-30 12:58

本文主要是介绍gurobi与python应用之数组生成,转换,修改,存储及读取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

gurobi与python应用篇1

    • 1.数组生成,转换,修改,存储及读取

1.数组生成,转换,修改,存储及读取

matlab输入矩阵很简单,直接用分号表示下一行即可。
而python不同,一维是list,二维是list中包含list

用普通方法创建的数组分隔符有逗号,而numpy创建的数组分隔符默认为空格(见代码块2,numpy生成的更方便!推荐这种)。

// 一维数组:list
a = [10,20,30,25,12,16,23,21,18,16];
// 二维数组:list中放list
a = [[1, 2, 3], [4, 5, 6]];
m = [[0]*5 for i in range(3)]
// numpy创建数组
from numpy import *
m1 = array([arange(1,4),arange(4,7),arange(7,10),arange(10,13),arange(13,16),arange(16,19)])  # 创建63列的二维数组
print(m1)
print("-"*50)  # 分割线

当然,一维数组和多维数组也可以相互转化。
(1).reshape:将一维数组变成多维数组
用法:一维数组名.reshape(x,y,z)将一维数组改成三维数组
(2).ravel或flatten:将多维数组变为一维数组
用法:数组名.ravel()或 数组名.flatten()
(3).shape:将 高维数组 转换成 低维数组
用法:数组名.shape(x行,列)
(4).transpose:将数组进行转置
用法:数组名.transpose()

数组也可以存储
savetxt
用法:savetxt(“文件名.txt”,数组名,fmt=数组格式,delimiter=’;’)
补充:数组格式可以为 整数型(%d)浮点型(%f)

// 将数组存储到txt中
from numpy import *
m1 = array([arange(1,4),arange(4,7),arange(7,10),arange(10,13),arange(13,16),arange(16,19)])  # 创建63列的二维数组
print(m1)
print("-"*50)  # 分割线
savetxt("文件名.txt",m1,fmt='%d',delimiter=';')

数组的读取:
loadtxt
用法:新数组 = loadtxt(“文件名.txt”,dtype=‘数组格式’,delimiter=’,’)
补充:数组格式可以为 整数型(int)浮点型(float)

from numpy import *print("-"*50)  # 分割线
a = loadtxt("文件名.txt",dtype=int,delimiter=';')
print(a)  # 将数组转置
print("-"*50)  # 分割线

关于数组的处理: 见这篇.

这篇关于gurobi与python应用之数组生成,转换,修改,存储及读取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/552908

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#