在python中解压缩大列表

弗朗切斯科

我必须解压缩这个大列表,然后将每个项目放入db。除了这些数据之外,其他所有东西都运行良好。

我尝试了:

([styles], [seasons], [day], [id]) = search_

但我收到这样的错误:

exception=ValueError('too many values to unpack (expected 4)')>

我使用这样的查询:

insert= "INSERT INTO cantina (styles,seasons,day,id) VALUES (?,?,?,?)"
db.execute(insert,(styles,seasons,day,id))

我知道我犯了一个错误,但是这里每行有4个字段,看来是正确的

search_ = [[["Redwine"], ['04'], ['01'], ['81535']],
[["Redwine"], ['04'], ['02'], ['81536']],
[["Redwine"], ['04'], ['03'], ['81537']],
[["Redwine"], ['04'], ['04'], ['81538']],
[["Redwine"], ['04'], ['05'], ['81539']],
[["Redwine"], ['04'], ['06'], ['81540']],
[["Redwine"], ['04'], ['07'], ['81541']],
[["Redwine"], ['04'], ['08'], ['81542']],
[["Redwine"], ['04'], ['09'], ['81543']],
[["Redwine"], ['04'], ['10'], ['81544']],
[["Redwine"], ['04'], ['11'], ['81545']],
[["Redwine"], ['04'], ['12'], ['81546']],
[["Redwine"], ['02'], ['01'], ['97179']],
[["Redwine"], ['02'], ['02'], ['97180']],
[["Redwine"], ['02'], ['03'], ['97181']],
[["Redwine"], ['02'], ['04'], ['97182']],
[["Redwine"], ['02'], ['05'], ['97183']],
[["Redwine"], ['02'], ['06'], ['97184']],
[["Redwine"], ['02'], ['07'], ['97185']],
[["Redwine"], ['02'], ['08'], ['97186']],
[["Redwine"], ['02'], ['09'], ['97187']],
[["Redwine"], ['02'], ['10'], ['97188']],
[["Redwine"], ['02'], ['11'], ['97189']],
[["Redwine"], ['02'], ['12'], ['97190']]]

([styles], [seasons], [day], [id]) = search_

insert= "INSERT INTO cantina (styles,seasons,day,id) VALUES (?,?,?,?)"
db.execute(insert,(styles,seasons,day,id))

编辑 :

嗨,Barmar,因为该列表来自另一个函数,通过该函数,我加入了四个列表:

def cantina ( cantina_id)
  for ... in ...:
     styles = 
     season  = 
     day = 
     id = 
     result.append([[styles], [season], [day], [id]]])
  return result

而“追加”仅接受一个参数。

我必须基于“ cantina_id”处理一些数据;将其添加到四个列表并将其保存到数据库

巴尔玛

您需要循环遍历search_并分别处理每一行。

insert= "INSERT INTO cantina (styles,seasons,day,id) VALUES (?,?,?,?)"
for row in search_:
    ([styles], [seasons], [day], [id]) = row
    cur.execute(insert,(styles,seasons,day,id))
db.commit()

如果您更改cantina函数以使其不创建所有那些单元素列表,则可以使用executemany()

def cantina ( cantina_id)
  result = []
  for ... in ...:
     styles = 
     season  = 
     day = 
     id = 
     result.append([styles, season, day, id])
  return result

search_ = cantina(some_id)
insert= "INSERT INTO cantina (styles,seasons,day,id) VALUES (?,?,?,?)"
cur.executemany(insert, search_)
db.commit()

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章