无法弄清楚我的条件有什么问题
Can't figure out what is wrong with my conditional
这是一个网络抓取程序代码我正在 运行 将我所有的大学模块移植到 csv 文件中,但我无法理解为什么我的 if/else 语句不起作用,尝试了很多不同的方法解决方案,但仍然没有运气。也许我错过了什么?
这是代码(条件在底部):
from bs4 import BeautifulSoup, BeautifulStoneSoup
# import requests
import csv
with open('timetable.html', encoding='UTF-8', newline='') as html_file:
soup = BeautifulSoup(html_file, 'lxml')
csv_file = open('lol.csv', 'w', encoding='utf-8')
csv_writer = csv.writer(csv_file)
csv_writer.writerow(['Subject', 'Start date', 'Start time', 'End time', 'Location'])
table = soup.find('table')
for modulis in table.find_all('td', class_='modclass'):
# randam modulį
# randam modulio pavadinimą
pav = modulis.find_all('a')[1]
name = pav['title']
print(name)
# modulio laiko pradžia
time1 = modulis.text[0:5]
print(time1)
# modulio laiko pabaiga
time2 = modulis.text[6:11]
print(time2)
# modulio vieta
aud = modulis.find('a').text[1:]
print(aud)
# modulio data
data = modulis.parent.find('td', class_='date').text
if data[0] == 0:
rand = '2019.' + data
else:
rand = '2018.' + data
# rašom csv
print(rand)
csv_writer.writerow([name, rand, time1, time2, aud])
它永远不会评估为真,所以它总是进入 else 语句,蚂蚁输入了错误的年份。
我所有的日期都以 2018.xx.xx 结尾,但这些以 0 开头的月份应该以 2019.xx.xx
开头
此外,数据始终采用 xx.xx 格式,因此数据 [0] 始终选择第一个数字。
您将 data
设置为文本,然后将其计算为 int。只需将其更改为“0”即可。
...
data = modulis.parent.find('td', class_='date').text
if data[0] == '0':
rand = '2019.' + data
else:
rand = '2018.' + data
...
这是一个网络抓取程序代码我正在 运行 将我所有的大学模块移植到 csv 文件中,但我无法理解为什么我的 if/else 语句不起作用,尝试了很多不同的方法解决方案,但仍然没有运气。也许我错过了什么? 这是代码(条件在底部):
from bs4 import BeautifulSoup, BeautifulStoneSoup
# import requests
import csv
with open('timetable.html', encoding='UTF-8', newline='') as html_file:
soup = BeautifulSoup(html_file, 'lxml')
csv_file = open('lol.csv', 'w', encoding='utf-8')
csv_writer = csv.writer(csv_file)
csv_writer.writerow(['Subject', 'Start date', 'Start time', 'End time', 'Location'])
table = soup.find('table')
for modulis in table.find_all('td', class_='modclass'):
# randam modulį
# randam modulio pavadinimą
pav = modulis.find_all('a')[1]
name = pav['title']
print(name)
# modulio laiko pradžia
time1 = modulis.text[0:5]
print(time1)
# modulio laiko pabaiga
time2 = modulis.text[6:11]
print(time2)
# modulio vieta
aud = modulis.find('a').text[1:]
print(aud)
# modulio data
data = modulis.parent.find('td', class_='date').text
if data[0] == 0:
rand = '2019.' + data
else:
rand = '2018.' + data
# rašom csv
print(rand)
csv_writer.writerow([name, rand, time1, time2, aud])
它永远不会评估为真,所以它总是进入 else 语句,蚂蚁输入了错误的年份。 我所有的日期都以 2018.xx.xx 结尾,但这些以 0 开头的月份应该以 2019.xx.xx
开头此外,数据始终采用 xx.xx 格式,因此数据 [0] 始终选择第一个数字。
您将 data
设置为文本,然后将其计算为 int。只需将其更改为“0”即可。
...
data = modulis.parent.find('td', class_='date').text
if data[0] == '0':
rand = '2019.' + data
else:
rand = '2018.' + data
...