Python json запись в csv: AttributeError: ‘list’ object has no attribute ‘str’

261 просмотра
0
0 Комментариев

Добрый день Есть json

var model = {"ALLSKUS":["84664020","07961015","84664113","84664116"],"NBR":"137127","PRICERANGE":"$186.99 - $189.99","GENDER_AGE":"Men's","PRICEADJUSTDATE":"","AVAILABLE_SIZES":[" 07.5"," 08.0"," 08.5"," 09.0"," 09.5"," 10.0"," 10.5"," 11.0"," 11.5"," 12.0"," 12.5"," 13.0","14.0","15.0"],"DISCOUNT_PERCENT":"15","isFieldTestable":false,"SORT":"152","HASCUSTOMPRODUCTTEMPLATE":false,"PR_LIST":"224.99","SPORTS":[{"ID":"3","NM":"Basketball"},{"ID":"39","NM":"Casual"}],"SIZECHART_CD":"S0584","HASSIZES":true,"PR_SALE":"189.99","LOCALIZATION":{},"MODELTEMPLATE":{"ISMODELTEMPLATEACTIVE":"N","MODELTEMPLATE_IMAGE":""},"ISCUSTOMPRODUCT":false,"INTRODUCTIONDATE":"","SKU":"84664020","ISINTANGIBLE":false,"PROD_TP":"Shoes","CUSTPROD_CD":"","NM":"Jordan Retro 6 - Men's","REVIEWS":

[/apcode]

  1. я ищу это

    "AVAILABLE_SIZES":[" 07.5"," 08.0"," 08.5"," 09.0"," 09.5"," 10.0"," 10.5"," 11.0"," 11.5"," 12.0"," 12.5"," 13.0"," 14.0"," 15.0"]
    

потом я убираю все лишнее

  1. На выходе должно быть таблица.csv

    |размер|размер|размер|размер|размер|размер|размер|размер|размер|размер|
    |07.0|07.5|08.0|10.0|10.5|11.5|12.0"|13.0|14.0|15|
    

  2. Пишу это в csv

Данные я ищу через регулярные выражения:

ad = requests.get('http://www.footlocker.com/product/model:132512/sku:A1781919/timberland-roll-top-mens/tan/tan/').text #сылка для примера
 bb = re.findall(r'"AVAILABLE_SIZES":(.*)"DISCOUNT_PERCENT"', ad)
out: ['[" 07.0"," 07.5"," 08.0"," 10.0"," 10.5"," 11.5"," 12.0"," 13.0"," 14.0"," 15.0"],']

[/apcode]

Дальше я их убираю лишнее данные

как теперь убрать лишнее?
На replace ругается.
На выходе ошибка, пробела в некорректном выводе json?

 out:
bb = re.findall(r'"AVAILABLE_SIZES":(.*)],"DISCOUNT_PERCENT"', ad).str(var).replace('[', ' ')
AttributeError: 'list' object has no attribute 'str'

[/apcode]

update

bb_strings = re.findall(r'var model = ({.*})', ad)
    bp = {}
    if bb_strings:
    bp = json.loads(bb_strings[0])
out: {'ALLSKUS': ['A1781919', '6635A001', '6634A'], 'NBR': '132512', 'PRICERANGE': '$99.99 - $125.99', 'GENDER_AGE': "Men's", 'PRICEADJUSTDATE': '', 'AVAILABLE_SIZES': [' 07.0', ' 07.5', ' 08.0', ' 10.0', ' 10.5', ' 11.5', ' 12.0', ' 13.0', ' 14.0', ' 15.0'], 'DISCOUNT_PERCENT': '10', 'isFieldTestable': False, 'SORT': '1036', 'HASCUSTOMPRODUCTTEMPLATE': False, 'PR_LIST': '139.99', 'SPORTS': [{'ID': '31', 'NM': 'Snow'}, {'ID': '39', 'NM': 'Casual'}], 'SIZECHART_CD': 'S0629', 'HASSIZES': True, 'PR_SALE': '125.99', 'LOCALIZATION': {}, 'MODELTEMPLATE': {'ISMODELTEMPLATEACTIVE': 'N', 'MODELTEMPLATE_IMAGE': ''}, 'ISCUSTOMPRODUCT': False, 'INTRODUCTIONDATE': '', 'SKU': '6635A001', 'ISINTANGIBLE': False, 'PROD_TP': 'Shoes', 'CUSTPROD_CD': '', 'NM': "Timberland Roll-Top - Men's", 'REVIEWS': {'HASREVIEWS': True, 'TOTALREVIEWCOUNT': '17', 'WEIGHTEDAVERAGERATING': '4.82', 'WEIGHTEDAVERAGERECOMMENDED': '16'}, 'BRAND': 'Timberland', 'INET_COPY': 'A style unlike any other. The Timberland Roll Top Boot rolls down for a little built-in air conditioning and a whole lotta style. Premium, full-grain leather upper provides comfort, durability and abrasion resistance. Direct-attach seam construction promises lasting durability. Padded collar provides a comfortable fit around the ankle and keeps out debris. Rubber lug sole for traction and durability. Embossed Timberland tree logo on the side.'}
for bl in bp['AVAILABLE_SIZES']:
    footlocker.append(('размер', bl))

[/apcode]

все норм работает, как теперь сделать что в csv писались все данные а не первые значения?

теперь нужно достать данные которые нужны


Добавить комментарий

1 Ответы

Python Опубликовано 16.12.2018
0

re.findall() возвращает cписок (тип list). У списка нет метода str(). Помимо общих методов для (изменяемых) последовательностей, list предоставляет только sort() метод.

Интерактивно, в REPL (ptpython, ipython) поиграйтесь: посмотрите, что re.findall() возвращает, какие методы у списка автодополнение показывает. Полный список методов можно увидеть в выводе help(list).

См. Как получить информацию из строки json, которая указана в Javascript коде внутри html страницы, используя python3.x?

Добавить комментарий
Напишите свой ответ на данный вопрос.
Scroll Up