#coding=utf8
tp = [(1,221,331),(2,222,332),(3,223,333), (4,224,334), (5,225,335),(6,226,336)]
ids = [1,2,3,4,5,6]
i_ids = [1,2,4]
u_ids = [3,5,6]
i_list, u_list = [],[]
def generate(i_ids, u_ids, dataList):
#flag:标识,1则mainIds为insert, 0则mainIds为update
#dataList:数据列表
#i_ids:insert id 列表
#u_ids:update id 列表
#@return (insert_list, update_list)
data_list = dataList
if len(i_ids) == 0:
update_list = data_list
insert_list = []
elif len(u_ids) == 0:
insert_list = data_list
update_list = []
else:
insert_list = []
update_list = []
mainIds,seconIds,flag = (u_ids,i_ids, 0) if len(i_ids) > len(u_ids) else (i_ids,u_ids, 1)
def loops(main_ids, d_list):
m_list, s_list = [], []
for i in main_ids:
for j in d_list:
if i == j[0]:
m_list.append(d_list.pop(d_list.index(j)))
break
s_list = d_list
return m_list, s_list
a,b = loops(mainIds, data_list)
insert_list, update_list = (a, b) if flag == 1 else (b, a)
return insert_list, update_list
print generate(i_ids, u_ids, tp)