Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/database/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
电话簿数据库帮助-Python_Python_Database_Python 2.7 - Fatal编程技术网

电话簿数据库帮助-Python

电话簿数据库帮助-Python,python,database,python-2.7,Python,Database,Python 2.7,我是编程新手,有一项工作已经做了一段时间了。我理解定义函数和很多基础知识,但在这一点上我遇到了麻烦 我试图弄明白这一点,但还不太明白“类”特性是如何工作的。我非常感谢您对我的帮助;另外,任何关于一些python资源的帮助都可以简化类的使用方式/原因 您将在工作中从事一个数据库项目已有一段时间了。您的老板鼓励您使用Python编程数据库。您不同意,认为Python不是一种数据库语言,但您的老板坚持为示例电话数据库提供以下源代码 他要求你做两件事: 评估现有的源代码,并对其进行扩展,使其对公司的经

我是编程新手,有一项工作已经做了一段时间了。我理解定义函数和很多基础知识,但在这一点上我遇到了麻烦

我试图弄明白这一点,但还不太明白“类”特性是如何工作的。我非常感谢您对我的帮助;另外,任何关于一些python资源的帮助都可以简化类的使用方式/原因


您将在工作中从事一个数据库项目已有一段时间了。您的老板鼓励您使用Python编程数据库。您不同意,认为Python不是一种数据库语言,但您的老板坚持为示例电话数据库提供以下源代码

他要求你做两件事:

  • 评估现有的源代码,并对其进行扩展,使其对公司的经理有用。(您不需要GUI界面,只需处理数据库方面的工作:数据输入和检索-当然,您必须让程序运行或正常工作

  • 他希望您对Python作为数据库工具进行批判性评估


  • 将下面的示例代码导入到Python IDLE中,并对其进行增强、运行和调试。通过提供方便的数据输入和检索功能,添加一些功能,使其成为更现实的数据库工具

    import shelve
    import string
    
    UNKNOWN = 0
    HOME = 1
    WORK = 2
    FAX = 3
    CELL = 4
    
    class phoneentry:
        def __init__(self, name = 'Unknown', number = 'Unknown',
                        type = UNKNOWN):
                self.name = name
                self.number = number
                self.type = type
    
        #  create string representation
        def __repr__(self):
                return('%s:%d' % ( self.name, self.type ))
    
        #  fuzzy compare or two items
        def __cmp__(self, that):
                this = string.lower(str(self))
                that = string.lower(that)
    
                if string.find(this, that) >= 0:
                        return(0)
                return(cmp(this, that))
    
        def showtype(self):
                if self.type == UNKNOWN: return('Unknown')
                if self.type == HOME: return('Home')
                if self.type == WORK: return('Work')
                if self.type == FAX: return('Fax')
                if self.type == CELL: return('Cellular')
    
    class phonedb:
        def __init__(self, dbname = 'phonedata'):
            self.dbname = dbname;
            self.shelve = shelve.open(self.dbname);
    
        def __del__(self):
            self.shelve.close()
            self.shelve = None
    
        def add(self, name, number, type = HOME):
            e = phoneentry(name, number, type)
        self.shelve[str(e)] = e
    
    def lookup(self, string):
        list = []
        for key in self.shelve.keys():
            e = self.shelve[key]
            if cmp(e, string) == 0:
                list.append(e)
    
        return(list)
    
    # if not being loaded as a module, run a small test
    
    if __name__ == '__main__':
        foo = phonedb()
        foo.add('Sean Reifschneider', '970-555-1111', HOME)
        foo.add('Sean Reifschneider', '970-555-2222', CELL)
        foo.add('Evelyn Mitchell', '970-555-1111', HOME)
    
        print 'First lookup:'
        for entry in foo.lookup('reifsch'):
            print '%-40s %s (%s)' % ( entry.name, entry.number, entry.showtype() )
        print
    
        print 'Second lookup:'
        for entry in foo.lookup('e'):
            print '%-40s %s (%s)' % ( entry.name, entry.number, entry.showtype() )
    
    我不确定自己是否走上了正确的道路,但以下是我目前掌握的情况:

    def openPB():
        foo = phonedb()
        print 'Please select an option:'
        print '1 - Lookup'
        print '2 - Add'
        print '3 - Delete'
        print '4 - Quit'
        entry=int(raw_input('>> '))
        if entry==1:
                namelookup=raw_input('Please enter a name: ')
                for entry in foo.lookup(namelookup):
                        print '%-40s %s (%s)' % (entry.name, entry.number, entry.showtype() )
        elif entry==2:
                name=raw_input('Name: ')
                number=raw_input('Number: ')
                showtype=input('Type (UNKNOWN, HOME, WORK, FAX, CELL): \n>> ')
                for entry in foo.add(name, number, showtype):           #Trying to figure out this part
                        print '%-40s %s (%s)'% (entry.name, entry.number, entry.showtype() )
        elif entry==3:
                delname=raw_input('Please enter a name to delete: ')
                #                                                       #Trying to figure out this part
                print "Contact '%s' has been deleted" (delname)
        elif entry==4:
                print "Phone book is now closed"
                quit
        else:
                print "Your entry was not recognized."
                openPB()
    
    openPB()
    
    ,和内置的都是开始学习Python的人非常好的资源。我开始学习Python时也使用了这些资源