比如导入结巴分词,代码如下:
import jieba # 引入母模块-很土的名字,不知道是否有专业名字?
然后直接使用结巴的子模块 posseg 来标注词性,代码如下:
jieba.posseg.cut('中文词性标注') # 这句报异常:
#=>AttributeError: 'module' object has no attribute 'posseg'
必须这样导入子模块,才能使用:
from jieba import posseg
posseg.cut('中文词性标注') # 这句正常调用
看到常说推荐直接导入母模块,以防止命名空间污染;而且一般如:
from a import b
b.func('中文词性标注')
这样格式的代码,都能转为这样来使用:
import a
a.b.func('中文词性标注')
但为什么 jieba 结巴分词却不能这样呢?这是什么原因呢?
感谢您的回复!
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.