使用Python 1.5个月。我在这里使用Python 3.3.2和WinPython http://code.google.com/p/winpython/以及端口xlwt到Python 3 https://github.com/hansrwl/xlwt/tree/py3 这是dict,值为列表。它使用以下函数正确写入xls文件。
sampleData = {'Books': ['Book_A', 'Book_B', 'Book_C'],
'Author': ['Author_A', 'Author_B', 'Author_C'],
'Price': ['Price_A', 'Price_B', 'Price_C']}
功能:
def saveDataToNewFile(fileName, sheetName, data):
# Creating new workbook
wb = xlwt.Workbook()
# Creating new worksheet with the name specified
ws = wb.add_sheet(sheetName)
# Use dictionary keys as first row values(e.g. headers)
for colIdx, headerCaption in enumerate(data):
ws.write(0, colIdx, headerCaption)
# Use dict values as row values for corresponding columns
for rowIdx, itemVal in enumerate(data[headerCaption]):
ws.write(rowIdx + 1, colIdx, itemVal)
wb.save(fileName)
saveDataToNewFile('sample.xls', 'FirstSaveToXlsSample', sampleData)
- 这已正确保存并使用MS Excel打开。
我有这个循环产生的相同数据结构:
soup3 = defaultdict(list)
def init_fields(links_first_lvl):
for link in links_first_lvl[1:7]:
soup3['Дата'].append(BeautifulSoup(urllib.request.urlopen(link).read()).select('.author_data'))
soup3['Адрес'].append(link)
return soup3
这是结构,字典以列表作为值(我使用pprint在控制台美容中打印)
PPRINT:
{'url': [ 'http://www.ros.ru/article.php?chapter=1&id=20132503',
'http://www.ros.ru/article.php?chapter=1&id=20132411'],
'date': [[<div class="author_data"><b>Марта Моисеева
</b> № 30 (973) от 24.07.2013
<span class="rubr"> ВЛАСТЬ
</span></div>],
[<div class="author_data"><b>Ольга Космынина
</b> № 29 (972) от 17.07.2013
<span class="rubr"> ВЛАСТЬ
</span></div>]]
saveDataToNewFile('sample2.xls', 'FirstSaveToXlsSample', soup3)
问题:如果我尝试保存到xls,我会收到错误:
.....
if isinstance(data, basestring):
NameError: global name 'basestring' is not defined
编辑:这是控制台Pycharm中的完整错误堆栈
Traceback (most recent call last):
File "F:/Python/NLTK packages/parse_html_py3.3.2.py", line 91, in <module>
saveDataToNewFile('sample2.xls', 'FirstSaveToXlsSample', soup3)
File "F:/Python/NLTK packages/parse_html_py3.3.2.py", line 87, in saveDataToNewFile
ws.write(rowIdx + 1, colIdx, itemVal)
File "F:\WinPython-32bit-3.3.2.0\python-3.3.2\lib\site-packages\xlwt\Worksheet.py", line 1032, in write
self.row(r).write(c, label, style)
File "F:\WinPython-32bit-3.3.2.0\python-3.3.2\lib\site-packages\xlwt\Row.py", line 259, in write
self.__rich_text_helper(col, label, style, style_index)
File "F:\WinPython-32bit-3.3.2.0\python-3.3.2\lib\site-packages\xlwt\Row.py", line 276, in __rich_text_helper
if isinstance(data, basestring):
NameError: global name 'basestring' is not defined
我不知道为什么,它应该起作用,因为结构是一样的。
答案 0 :(得分:0)
您正在使用的库只能在python 2.x上运行。从here下载最新的python 2.x,然后重试。
答案 1 :(得分:0)
LibreOffice的开销要低得多。打开LibreOffice安装文件夹,并从那里的所有当前示例中搜索您的UNO引用。另存为XLS。完成。
答案 2 :(得分:0)
正如评论所示,问题是您使用的代码仍然是为Python 2编写的,但是,在您按照nosklo建议降级到Python 2之前,请确保从Python 3分支安装了xlwt < / strong>即可。克隆xlwt存储库后,您是否记得执行
git checkout -b py3 origin/py3
在执行安装之前?
如果你记得并且你仍然得到基本字符串错误,那么py3分支仍然不完整,你需要降级到Python 2以在主分支中运行代码。
答案 3 :(得分:0)
您可以尝试将'basestring'更改为'str'
答案 4 :(得分:0)
if isinstance(data, basestring):
NameError: global name 'basestring' is not defined
对象可能没有这样的属性而你的测试失败了,因为它只是测试对象类型是否是一个实例,它暗示你的属性或对象已经存在。
我建议您执行先前的测试以验证属性或对象是否存在,例如hasattr(),或者如果您考虑使用 self ,您可以阅读 self .__ dict __ 找到现有属性。