环境:这几天在使用python开发程序的过程中,需要连接到mysql数据库,而且涉及到不同的服务器和不同的数据库,前期使用测试服来做测试,不想在python程序里频繁去更改数据库的配置信息,于是想到将全部的数据库配置写进一个db.conf文件里去读取,也是基于安全性的考虑。 于是写了一个基于固定格式的文件读取程序,案例如下。 测试文件内容: title1 1,line 1 2,line 2 3,line 3 title2 4,line 4 5,line 5 6,line 6 title3 7,line 7 8,line 8 9,line 9
程序文件:
def open_file(filename, mode=‘r‘): """ :param filename: :param mode: :return: 返回文件句柄 """ try: the_file = open(filename, mode) except IOError: print "Unable to open the file", filename sys.exit(0) else: return the_file def next_line(the_file): """ :param the_file: :return: 读取一行文件内容 """ line = the_file.readline() return line def next_block(the_file): """ :param the_file: :return: 读取指定格式的一段内容 """ title = next_line(the_file) # cg = next_line(the_file) content = [] for i in range(3): #3为文件内容的行数 content.append(next_line(the_file)) return title, content my_file = open_file(‘1.txt‘, ‘r‘) a = raw_input("enter you name: ") #可以在函数中以变量来调用,这里仅做测试用 for i in range(3): #3为格式内容的段数 tit = next_block(my_file) if a == tit[0].strip(‘\n‘): print "TITLE IS :", tit[0] for j in range(3): print "content ", (j+1), "is: ", tit[1][j].strip(‘\n‘) break else: print ‘no this title‘ exit(0)
这样,对于我的数据库配置信息就很好根据需要来进行获取了,只需要将title放进python程序就可以去处对应的数据库连接信息
[test]
user:root
password:123456
db_name:study
host:127.0.0.1
port:3306
charset:utf8
[mysql]
user:root
password:123456
db_name:wwwsite
host:127.0.0.1
port:3306
charset:utf8
。。。。。
本文出自 “方向感” 博客,请务必保留此出处http://itech.blog.51cto.com/192113/1767451
原文地址:http://itech.blog.51cto.com/192113/1767451