from gurobipy import *
import random
# 创建模型,实例化一个
MODEL = Model()
# 可以将 '*' 理解为切片操作(列表的 list[:])
#ub=GRB.INFINITY上界无穷大
x=MODEL.addVar(name="x",lb=0,ub=GRB.INFINITY)#vtype=GRB.BINARY是指定为0-1的变量,vtyep=GRB.CONTINUOUS设置为连续性
y=MODEL.addVar(name="y",lb=0,ub=GRB.INFINITY)#vtyep=GRB.INTEGER 整型
z=MODEL.addVar(name="z",ub=GRB.INFINITY)
#w=MODEL.addVars(2,3,name='w')
#a=MODEL.addConstrs((w.sum(i,'*')<=1 for i in range(3)),'c0')
#quicksum(i*i for i,j in range(3))
#2.prod(3)
MODEL.setObjective(-3*x-2*y-z,GRB.MINIMIZE)#极小化,MAMIMIZE极大化
#print(a)
MODEL.addConstr(x+y+z<=7,'c0')
MODEL.addConstr(4*x+2*y+z==12,'c1')
#==1是限制有且只有一次
MODEL.addConstr(z==random.randint(0,1),'c4')#或者random.choice([0,1])
MODEL.update()#更新变量环境
#print(w)
#try:
# pass
#except Exception as e:
MODEL.optimize()#运行模型
for v in MODEL.getVars():
print('%s %g' %(v.varName,v.x))#print(f"{x.varName}:{round(x.X)}")
print("obj:"'%g'% MODEL.objVal)
MODEL.write('aa.lp')