首页
注册
登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请
登录
推荐学习书目
›
Learn Python the Hard Way
Python Sites
›
PyPI
- Python Package Index
›
http://diveintopython.org/toc/index.html
›
Pocoo
值得关注的项目
›
PyPy
›
Celery
›
Jinja2
›
Read the Docs
›
gevent
›
pyenv
›
virtualenv
›
Stackless Python
›
Beautiful Soup
›
结巴中文分词
›
Green Unicorn
›
Sentry
›
Shovel
›
Pyflakes
›
pytest
Python 编程
›
pep8 Checker
Styles
›
PEP 8
›
Google Python Style Guide
›
Code Style from The Hitchhiker's Guide
V2EX
›
Python
如何一次装载,多次调用?
omg21
·
2016-12-29 14:14:20 +08:00
· 2195 次点击
这是一个创建于 3020 天前的主题,其中的信息可能已经有所发展或是发生改变。
我现在做的一个模块是在字符串中匹配城市名,比如:
print(printCityName('上海市 2016 事业单位招聘计划'))
结果显示:'上海市'
在这个模块里首先从数据库中取出全部城市名,取出来后存到一个列表里),执行 printCityName()时在列表里挨个试,直到取出符合条件的内容为止,取不出来输出''。
我这样做是想让主程序内容更少些,但是这样做的结果就是每次都要读取数据库,内容少还行,如果有几百万条几千万条数据,那就太累了。
应该怎么做能一次性把数据库装载到内存里,然后多次调用呢?
数据库
调用
取出
装载
7 条回复
•
2016-12-31 21:04:13 +08:00
1
liuqhang
2016-12-29 14:31:30 +08:00
redis
2
jiuanjing
2016-12-29 19:03:59 +08:00 via iPhone
几百万条数据全部装内存里,这个想法很危险
3
omg21
OP
2016-12-29 21:28:49 +08:00
@
jiuanjing
不是啊,我只是要把全国的城市名和县区名装到内存里
4
jiuanjing
2016-12-29 22:56:38 +08:00 via iPhone
@
omg21
一个 arraylist 不就行了
5
omg21
OP
2016-12-30 14:08:44 +08:00
@
jiuanjing
@
liuqhang
搞定了,用了一个类,以前不习惯用类,现在才知道类的好处。把数据加载和查询分开成两个函数,放在一个类里,在主程序里各自调用就行了。
6
qile1
2016-12-31 19:12:35 +08:00 via Android
@
omg21
给个代码参考一下如何?学习一下,我也有个列表和数据库里面的列表比对归类!一直没有好办法。
7
omg21
OP
2016-12-31 21:04:13 +08:00
@
qile1
你要比对的话只能遍历一遍了,
citylist = ['北京','上海','南京','杭州'......]
textstr = '上海 2016 年事业单位招聘计划'
for city in citylist:
++if city in textstr:
++++print(city)
++++break
关于
·
帮助文档
·
博客
·
API
·
FAQ
·
实用小工具
·
2486 人在线
最高记录 6679
·
Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 21ms ·
UTC 06:49
·
PVG 14:49
·
LAX 23:49
·
JFK 02:49
Developed with
CodeLauncher
♥ Do have faith in what you're doing.