def __init__(self,Gname,Gnum,Gprice,ordernumber,Amount,Price,Date): self.Gname=Gname self.Gnum=Gnum self.Gprice=Gprice self.ordernumber=ordernumber self.Amount=Amount self.Price=Price self.Date=Date
时间: 2023-06-24 21:08:38 浏览: 116
这是一个 Python 类的构造函数,它有七个参数:Gname、Gnum、Gprice、ordernumber、Amount、Price 和 Date。在创建这个类的实例时,这些参数将被传递给构造函数,并用于设置该实例的属性。例如,如果你创建了一个名为 "order" 的对象,并传递了相应的参数,那么该对象将具有名为 "Gname"、"Gnum"、"Gprice"、"ordernumber"、"Amount"、"Price" 和 "Date" 的属性,并且这些属性将被设置为传递的值。
相关问题
func PostPurchaseList(a *decorator.ApiBase, data *adminStruct.PurchaseList) error { logger.AccessLogger.Info("PostPurchaseList....") res := adminStruct.PurchaseListResp{} //res.ResponseCommon = a.NewSuccessResponseCommon() query := a.Ts.Table("purchase_order_info a"). Select("a.poid,a.cuid,a.arrival_num,a.sum_num,a.goods_sum_amt,a.pur_amt,a.other_amt,a.sum_amt,whi.addr,whi.phone,whi.contacts"). Joins(`left join warehouse_info whi on a.wid = whi.wid`) if len(data.OrderNo) > 0 { query = query.Where("a.order_no like ?", fmt.Sprintf("%%%s%%", data.OrderNo)) } if len(data.Sku) > 0 { query = query.Where("gs.sku like ?", fmt.Sprintf("%%%s%%", data.Sku)) } if len(data.Gname) > 0 { query = query.Where("g.gname like ?", data.Gname) } if data.Wid > 0 { query = query.Where("a.wid like ?", data.Wid) } if data.Sid > 0 { query = query.Where("a.sid like ?", data.Sid) } if len(data.LogisticsId) > 0 { query = query.Where("a.logistics_id like ?", data.LogisticsId) } if len(data.Remark) > 0 { query = query.Where("a.remark like ?", data.Remark) } if len(data.ApplyPayStatus) > 0 { query = query.Where("a.arrival_status like ?", data.ApplyPayStatus) } if len(data.PayStatus) > 0 { query = query.Where("a.pay_status like ?", data.PayStatus) } if len(data.ArrivalStatus) > 0 { query = query.Where("a.arrival_status like ?", data.ArrivalStatus) } if data.ArrivalTime > 0 { query = query.Where(" a.arrival_time=?", data.ExpectCime-time.Now().Unix()) } if data.Ctime > 0 { query = query.Where(" a.ctime>=?", data.BeginDate) } if data.Ctime > 0 { query = query.Where(" a.ctime<=?", data.EndDate) } utils.Error(query.Limit(a.Size). Offset(a.Offset). Find(&res.Data).Error) var poids []int64 for _, i := range res.Data { poids = append(poids, i.Poid) } g := []adminStruct.GoodsInfo2{} utils.Error(a.Ts.Table("purchase_order_list b"). Select("b.poid,gs.sku,b.price,b.num,g.gname,g.image,b.polid,b.goods"). Joins(`left join goods_base g on g.gid=b.gid`). Joins(`left join goods_sku gs on gs.gsid = b.skuid`). Where("b.poid in ?", poids).Find(&g).Error) for i, _ := range res.Data { p := &res.Data[i] for _, i2 := range g { if i2.Poid == p.Poid { p.Detail = append(p.Detail, i2) } } } return a.ReturnSuccessCustomResponse(res) }
这段代码是一个名为 "PostPurchaseList" 的函数,它接受两个参数:指向decorator.ApiBase类型的指针a和指向adminStruct.PurchaseList类型的指针data。该函数的目的是根据传入的data参数中的条件查询数据库,并返回查询结果。
首先,函数创建了一个空的adminStruct.PurchaseListResp结构体res,用于存储查询结果。然后,通过调用logger.AccessLogger.Info方法记录日志信息。
接下来,函数创建了一个查询对象query,查询的目标表是"purchase_order_info a",并选择了一些字段。通过左连接warehouse_info表,查询还包括了该表的一些字段。
接下来,函数根据data中的条件逐个添加WHERE子句到query中。如果data中的OrderNo字段不为空,则添加一个类似"a.order_no like '%xxx%'"的条件语句。其他字段的处理方式类似。
然后,函数处理了data中的两个时间字段。如果data中的ArrivalTime字段大于0,则添加一个"a.arrival_time=?"的条件语句,其中参数是data.ExpectCime减去当前时间戳。如果data中的Ctime字段大于0,则添加一个"a.ctime>=?"和"a.ctime<=?"的条件语句,其中参数分别是data.BeginDate和data.EndDate。
接下来,函数通过调用query的Limit和Offset方法设置了查询的限制和偏移量,并将查询结果存储到res.Data中。
接下来,函数创建了一个空的int64类型切片poids,用于存储查询结果中的poid字段。
然后,函数创建了一个空的adminStruct.GoodsInfo2类型切片g,用于存储查询结果中的商品信息。
接下来,函数创建了一个查询对象,查询的目标表是"purchase_order_list b",并选择了一些字段。通过左连接goods_base表和goods_sku表,查询还包括了这两个表的一些字段。其中,查询条件为"b.poid in ?",参数为poids。
最后,函数对查询结果进行处理,将商品信息添加到对应的采购单中。
最后,函数通过调用a的ReturnSuccessCustomResponse方法返回查询结果res。
请注意,这段代码只是函数的实现部分,可能还有其他代码文件中定义的相关结构体、方法等。
this.commoditydata.some((item)=>{ var newArr = this.commoditydata.filter(function(item_gname){ return item_gname.gname==item.gname; //如果 commoditydata的gname 跟 item_gname的gname相同就返回 这样就根据gname查到这行数据 }); if(newArr.length>1) { this.$message.error("一件包裹不能有两个相同的品名") return true } })这段代码每一句都是什么意思,都有什么作用
这段代码是Vue.js的代码,主要作用是对一个名为`commoditydata`的数组进行遍历和筛选,然后判断是否存在两个相同的品名,如果存在就弹出错误提示。
具体解释如下:
1. `this.commoditydata`代表Vue实例中的一个名为`commoditydata`的数组。
2. `.some()`是数组的一个方法,用于遍历数组中的每一个元素,直到找到一个符合条件的元素,然后返回一个布尔值。在这里,它的作用是判断数组中是否存在两个相同的品名。
3. `var newArr = this.commoditydata.filter(function(item_gname){ return item_gname.gname==item.gname; });`这一行代码是对`commoditydata`数组进行筛选,将`gname`属性值等于当前元素的`gname`属性值的所有元素存储到一个新的数组`newArr`中。
4. `if(newArr.length>1)`判断`newArr`数组的长度是否大于1,如果大于1,就说明存在两个相同的品名。
5. `this.$message.error("一件包裹不能有两个相同的品名")`是Vue.js中的消息提示框,用于弹出错误提示信息。
6. `return true`是为了终止`some()`方法的执行。
综上所述,这段代码的作用是对数组中的元素进行遍历和筛选,判断是否存在两个相同的品名,并在存在时弹出错误提示。
阅读全文