URN Logo
UNIX Resources » Linux » China Linux Forum » Python 编 程 » 7 » 大家帮我看看这段代码有什么问题?
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
大家帮我看看这段代码有什么问题?
大家帮我看看这段代码有什么问题? - syncon [2005-08-17 18:45 | 1,072 byte(s)]
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Subject: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-17 18:45    Length: 1,072 byte(s)
[Original] [Print] [Top]

#! /usr/bin/python

import MySQLdb
import time

conn = MySQLdb.connect (host = "localhost",
user = "root",
passwd = "888888",
db = "test")
cursor = conn.cursor ()
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()

cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()

if rows2 is None:
for row in rows:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
else:
for row2 in rows2:
for row in rows:
if row[0] != row2[0]:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])

cursor.close ()
conn.close ()
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: limodou    Posted: 2005-08-17 18:54    Length: 14 byte(s)
[Original] [Print] [Top]
报什么错误呀?
----
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-17 18:55    Length: 128 byte(s)
[Original] [Print] [Top]
程序运行不报错,但不知道为什么,在这段代码中,如果usergroup为空的话,怎么都无法插入数据,而在usergroup中至少有一行,才能正常工作
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: limodou    Posted: 2005-08-17 19:03    Length: 211 byte(s)
[Original] [Print] [Top]
因为你的判断是:

if rows2 is None:

而使用fetchall()返回无记录时应为 [ ]
因此判断不正确。将上面的语句改为:

if not rows2:

试试
----
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-17 19:09    Length: 152 byte(s)
[Original] [Print] [Top]
多谢指点,还有个问题,就是执行结果,我的目的是要重customer中查找并写入到usergroup,如果在usergroup中已经有login_name存在,则不插入,可现在的结果不对了!
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: limodou    Posted: 2005-08-17 19:22    Length: 647 byte(s)
[Original] [Print] [Top]

for row2 in rows2:
for row in rows:
if row[0] != row2[0]:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])

这段判断有问题。你应该首先对rows进行循环,然后对于每个row判断
是否在rows2中即可,而不是一个个比较。

改为:

for row in rows:
if row not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])

另外在选择customer表时可以加上distinct关键字去掉重复值。
----
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-17 20:25    Length: 2,342 byte(s)
[Original] [Print] [Top]
初始状态:
mysql> select * from customer;
+--------+------------+--------------+
| status | last_date | login_name |
+--------+------------+--------------+
| OK | 2006-07-01 | nj0251234567 |
| OK | 2006-05-02 | nj0257654321 |
| OK | 2005-07-24 | njuf201 |
+--------+------------+--------------+

mysql> select * from usergroup;
Empty set (0.00 sec)

代码:
#! /usr/bin/python

import MySQLdb
import time

conn = MySQLdb.connect (host = "localhost",
user = "root",
passwd = "888888",
db = "test")
cursor = conn.cursor ()
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()

cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()

if not rows2:
for row in rows:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
else:
for row in rows:
if row[0] not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])

cursor.close ()
conn.close ()

第一次执行之后:
mysql> select * from usergroup;
+--------------+------+
| login_name | type |
+--------------+------+
| nj0251234567 | YES |
| nj0257654321 | YES |
| njuf201 | YES |
+--------------+------+
3 rows in set (0.00 sec)

如果再执行一次,结果:
mysql> select * from usergroup;
+--------------+------+
| login_name | type |
+--------------+------+
| nj0251234567 | YES |
| nj0257654321 | YES |
| njuf201 | YES |
| nj0251234567 | YES |
| nj0257654321 | YES |
| njuf201 | YES |
+--------------+------+
6 rows in set (0.00 sec)

这就达不到要求了!
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: limodou    Posted: 2005-08-17 20:59    Length: 20 byte(s)
[Original] [Print] [Top]
按我写的代码查一下。
----
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-17 21:53    Length: 812 byte(s)
[Original] [Print] [Top]
现在的问题是这样:

如果查询语句改成:
cursor.execute ("SELECT login_name FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()

那么用
for row in rows:
if row not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
就可以达到目的。

而我的两条查询语句查询的内容不同:
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()

所以就不行了,不知道有什么好的方法?
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-18 00:46    Length: 20 byte(s)
[Original] [Print] [Top]
斑竹帮我看看哦,谢谢
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: limodou    Posted: 2005-08-18 08:38    Length: 232 byte(s)
[Original] [Print] [Top]
那就把for row in rows:改为:


for row, date in rows:
...

后面的照旧。

东西要活学呀。其实你提的问题就是怎么把名字和日期分别取出来。
----
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-18 12:17    Length: 391 byte(s)
[Original] [Print] [Top]
for row,date in rows:
if row not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row)



for row in rows:
if row[0] not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])

不是一样的嘛,结果还是一样,郁闷...
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: syncon    Posted: 2005-08-18 13:05    Length: 204 byte(s)
[Original] [Print] [Top]
好像这样可以解决:
for row in rows:
if (row[0],) not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
呵呵,我再测试一下
[Original] [Print] [Top]
Subject: Re: 大家帮我看看这段代码有什么问题?
Author: limodou    Posted: 2005-08-18 21:11    Length: 706 byte(s)
[Original] [Print] [Top]
这就是你自已的问题了,你的原话:

而我的两条查询语句查询的内容不同:
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()

可见rows中的数据,一条记录返回两个元素,rows2一条记录返回一个元素。

所以你这样根本就是反的呀:

好像这样可以解决:
for row in rows:
if (row[0],) not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
呵呵,我再测试一下

而我的写法按你的说明应该是对的。
----
[Original] [Print] [Top]
« Previous thread
求在Zope中用Python_script上传文件的方法
Python 编 程
7
Next thread »
一个用zope写的论坛程序
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 04:11:05, cost 0.10462093353271 ms.