Python:在列表中创建换行符以便 openpyxl 在 .xlsx 中识别

标签 python python-3.x beautifulsoup openpyxl

我正在从 URL 中抓取信息

我可以成功将信息获取到一个.xlsx

它不是我想要的格式。

element_rows = []
for table_row in Elements.findAll('tr'):
    columns = table_row.findAll('td')
    output_row = []
    for column in columns:
        sub_rows = column.findAll('p')
        output_row.append('\r\n'.join(row.text for row in sub_rows))
    element_rows.append(output_row)

感觉很简单,就是放不下

随着它的迭代,我希望它为每个“p”创建一个新行。

我一直在尝试使用 Excel 语法“\r\n”,但感觉这是不对的。 我试过追加(行),但这会给我带来错误

目前它给了我一些类似的东西;

 |A    |B
1|Apple|PearOrangeBanana
2|Grape|MandarinOliveTomato

我愿意这样

 |A    |B
1|Apple|Pear
2|     |Orange
3|     |Banana
4|Grape|Mandarin
5|     |Olive
6|     |Tomato

好的。完整代码如下。

from bs4 import BeautifulSoup
import requests
import csv
from subprocess import Popen
import webbrowser
import re
from openpyxl import *
import tkinter as tk
import openpyxl
from itertools import zip_longest


#Variables
#Name of course
CourseName = 'AURAFA008'#input("Input Course Code: ")
#Base URL
TGAURL = 'https://training.gov.au/Training/Details/'
#.csv filename
CourseCSV = CourseName + '.csv'
CourseXLSX = CourseName + '.xlsx'
#Total URL of course
CourseURL = TGAURL + CourseName
#URL get
website_url = requests.get(CourseURL).text
#Beautiful soup work
soup = BeautifulSoup(website_url,'html.parser')
table = soup.table
#Excel Frameworks
# wb = Workbook()
wb = openpyxl.Workbook()
ws = wb.active
output_row = 1

#Open URL in browser
#webbrowser.open(CourseURL, 2)
# Define the tables I want to grab
Elements = (soup.find("h2", string="Elements and Performance Criteria")).find_next('table')
Foundation = (soup.find("h2", string="Foundation Skills")).find_next('table')
#Extract the data
Element_rows = []
for table_row in Elements.findAll('tr'):
    columns = table_row.findAll('td')
    output_row = []
    for column in columns:
        sub_rows = column.findAll('p')
        for row in sub_rows:
            output_row.append(row.get_text(separator=' '))
    Element_rows.append(output_row)

Foundation_rows = []

for table_row in Foundation.findAll('tr'):
    columns = table_row.findAll('td')
    output_row = []
    for column in columns:
        sub_rows = column.findAll('p')
        for row in sub_rows:
            output_row.append(row.get_text(separator=' '))
    Foundation_rows.append(output_row)


# Write the tables to .xlsx
Tab0 = (CourseName + 'Elements')
Tab1 = (CourseName + 'Foundation')
ws1 = wb.create_sheet(Tab0)
ws2 = wb.create_sheet(Tab1)

for row in Element_rows:
    ws1.append(row)
for row in Foundation_rows:
    ws2.append(row)
wb.remove(wb['Sheet'])
wb.save(CourseXLSX)
p = Popen(CourseXLSX, shell=True)

最佳答案

我建议您在进行过程中写入您的 excel 文件。对于每个表行,创建一个列表列表,其中包含存在的任何子行。然后您可以使用 Python 的 zip_longest()函数为每一行返回一个子条目,其中一个列表比另一个列表短,例如:

from itertools import zip_longest
from bs4 import BeautifulSoup
import openpyxl


html = """
<table>
  <tr>
    <td><p>a</p><p>b</p></td>
    <td><p>1</p><p>2</p><p>3</p></td>
    <td><p>d</p></td>
  </tr>
  <tr>
    <td><p>a</p><p>b</p></td>
    <td><p>1</p><p>2</p><p>3</p></td>
    <td><p>d</p></td>
  </tr>
</table>
"""

soup = BeautifulSoup(html, "html.parser")
table = soup.table

wb = openpyxl.Workbook()
ws = wb.active
output_row = 1

for table_row in table.find_all('tr'):
    cells = table_row.find_all('td')
    row = [[row.text for row in cell.find_all('p')] for cell in cells]

    for row_number, cells in enumerate(zip_longest(*row, fillvalue=""), start=output_row):
        for col_number, value in enumerate(cells, start=1):
            ws.cell(column=col_number, row=row_number, value=value)

    output_row += len(cells)

wb.save('output.xlsx')

这将为您提供以下输出:

Excel screenshot

enumerate()函数可用于为列表中的每个条目提供一个递增的数字。这可用于为 openpyxl 单元格提供合适的行号和列号。

关于Python:在列表中创建换行符以便 openpyxl 在 .xlsx 中识别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56864726/

相关文章:

c - Python调用C语言时,返回值异常

excel - 根据单元格值将 pandas DataFrame 导出到 Excel

python - 使用 BeautifulSoup 帮助解析 <pre> 标签

python - 字典键与值匹配时遇到问题

python - BeautifulSoup : extract 2 different tags and append them together in text only output

python - 在 Pandas 中用分组依据的总数百分比注释每一行?

python - 使用mainfile的 "object",在保存在其他文件中的函数中

python - 基本 django-rest-framework : how to get started writing a view?

python - 为什么我收到 500 内部服务器错误消息?

Python 没有名为 X 的模块 - 绝对导入