django-haystack / pysolr

Pysolr — Python Solr client
BSD 3-Clause "New" or "Revised" License
667 stars 340 forks source link

UnicodeDecodeError in _scrape_response #145

Closed oppianmatt closed 9 years ago

oppianmatt commented 9 years ago

There is this bit in the code:

            except SyntaxError as err:
                full_html = "%s" % response

It's trying to get the response into a str when the xml parsing fails.

But if that response contains unicode, that line will error.

The response it's trying to parse is:

'{"responseHeader":{"status":400,"QTime":281,"params":{"q":"*:*","facet.field":["facet_keywords_exact","grade","{!ex=category_exact}category_exact","hierarchy4"],"fl":"* score","start":"0","fq":["django_ct:(campsite.campsite)","{!geofilt pt=45.2065182704,0.826721191406 sfield=point d=25.749504}"],"f.facet_keywords_exact.facet.limit":"1000","rows":"1","facet":"on","wt":"json"}},"response":{"numFound":5,"start":0,"maxScore":1.0,"docs":[{"rating":"0","point":"45.4129972217,0.931974828309","grade":3,"text":"Camping le Repaire\\nCamping Le Repaire is in the beautiful region of P\xc3\xa9rigord, surrounded by trees, nature and rivers. Located only a short walk from the small village of Thiviers, this family-run campsite is ideal for a relaxing holiday with family and friends.\\r\\n\\r\\nOur facilities include:\\r\\n- two toilet/shower blocks\\r\\n- disabled access facilities\\r\\n- swimming pool\\r\\n- playground\\r\\n- bar and takeaway\\r\\n- laundry room\\r\\n\\r\\nPlay p\xc3\xa9tanque, play table football, ping pong or pool - or simply relax by the pool with an ice cream or an aperitif.\\r\\n\\r\\nOur friendly barbecues are not to be missed!\\nThiviers, Dordogne, Aquitaine, France\\nThiviers\\nDordogne\\nFrance\\nDordogne\\nfrance/aquitaine/dordogne/thiviers/camping-le-repaire\\ncamping-le-repaire\\n aa-pennant-none bar-nearby bar-or-club-house barbecues-allowed beach-excellent-water-quality beaches book-pitchup canoeingkayaking-nearby car-parking-by-pitch cycle-hire-nearby cycling-nearby disabled-facilities dogs-allowed dogs-allowed-all-year drainage-hook-up-points-for-tourers electrical-hook-up-points-for-tourers english family-friendly fishing free-wifi games-room gastronomic-delight hard-standings horse-riding-nearby is_balance_of_payment_taken_on_arrival jumbo-tent-pitches large-51-200-pitches launderette leisuretheme-park-nearby motorcycle-friendly motorhome-service-point nearby-farmers-market on-site-restaurantcafe outdoor-pool-nearby outdoor-swimming-pool peaceful play-area public-telephone rallies-welcome recycling-available restaurant-nearby shop-nearby shower-available take-away tennis-nearby toilet-block tv-room washing-up-area water-hook-up-points-for-tourers wifi \\nOur campsite is a few minutes from Thiviers, the capital of foie gras and truffles, so make sure you taste the exquisite local cuisine.\\r\\n\\r\\nA must visit is the Grottes de Villars (10km), a cave with 17,000-year-old prehistoric paintings, stalactites and other cave formations. \\r\\n\\r\\nKids will love the Chateau de Puyguilhem (11km), a sixteenth century castle listed as a historic monument by UNESCO.\\r\\n\\r\\nOr go to one of the many summer concerts in the ruins of Abbey de Boschaud, a twelfth century Cistercian monastery.\\n\\n    Barbecues allowed\\n\\n    Games room\\n\\n    Water hook-up points for tourers\\n\\n    On-site restaurant/cafe\\n\\n    Drainage hook-up points for tourers\\n\\n    Electrical hook-up points for tourers\\n\\n    Shower available\\n\\n    Cycling nearby\\n\\n    Nearby farmers' market\\n\\n    Fishing\\n\\n    Leisure/theme park nearby\\n\\n    Canoeing/kayaking nearby\\n\\n    Take away\\n\\n    Cycle hire nearby\\n\\n    Dogs allowed all year\\n\\n    Recycling available\\n\\n    Car parking by pitch\\n\\n    Launderette\\n\\n    Bar or club house\\n\\n    Public telephone\\n\\n    Horse riding nearby\\n\\n    Outdoor swimming pool\\n\\n    Play area\\n\\n    Toilet block\\n\\n    TV room\\n\\n    Washing-up area\\n\\n    Bar nearby\\n\\n    Outdoor pool nearby\\n\\n    Restaurant nearby\\n\\n    Shop nearby\\n\\n    Tennis nearby\\n\\n    Wifi\\n\\n    Hard standings\\n\\n    Motorhome service point\\n\\n    Disabled facilities\\n\\n    Dogs allowed\\n\\n    Family friendly\\n\\n    Jumbo tent pitches\\n\\n    Free wifi\\n\\n    Large (51-200 pitches)\\n\\n    Rallies welcome\\n\\n    Motorcycle friendly\\n\\n    Peaceful\\n\\n    Gastronomic delight\\n","has_primary_photo":true,"django_ct":"campsite.campsite","facilities":["barbecues-allowed","games-room","water-hook-up-points-for-tourers","on-site-restaurantcafe","drainage-hook-up-points-for-tourers","electrical-hook-up-points-for-tourers","shower-available","cycling-nearby","nearby-farmers-market","fishing","leisuretheme-park-nearby","canoeingkayaking-nearby","take-away","cycle-hire-nearby","dogs-allowed-all-year","recycling-available","car-parking-by-pitch","launderette","bar-or-club-house","public-telephone","horse-riding-nearby","outdoor-swimming-pool","play-area","toilet-block","tv-room","washing-up-area","bar-nearby","outdoor-pool-nearby","restaurant-nearby","shop-nearby","tennis-nearby","wifi","hard-standings","motorhome-service-point","disabled-facilities","dogs-allowed","family-friendly","jumbo-tent-pitches","free-wifi","large-51-200-pitches","rallies-welcome","motorcycle-friendly","peaceful","gastronomic-delight"],"lead_price_one_night":0.0,"hierarchy_tree_exact":["france/aquitaine/dordogne/thiviers/","france/aquitaine/dordogne/","france/aquitaine/","france/"],"id":"campsite.campsite.12273","bookable":true,"category":["tent-pitches","touring-pitches","motorhomes"],"django_id":"12273","content_autocomplete_text":"\\n{\\n    \\"value\\": \\"Camping le Repaire, Thiviers\\",\\n    \\"tokens\\": [\\"Thiviers\\", \\"france/aquitaine/dordogne/thiviers/camping\\\\u002Dle\\\\u002Drepaire\\"],\\n    \\"categories\\": [\\n                    {\\"sprite_class\\": \\"tents\\", \\"id\\": 4, \\"name\\": \\"Tent pitches\\"}\\n                  \\n                    ,{\\"sprite_class\\": \\"tourers\\", \\"id\\": 3, \\"name\\": \\"Touring pitches\\"}\\n                  \\n                    ,{\\"sprite_class\\": \\"motorhomes\\", \\"id\\": 10, \\"name\\": \\"Motorhomes\\"}\\n                  ],\\n    \\"name\\": \\"Camping le Repaire, Thiviers\\",\\n    \\"url\\": \\"france/aquitaine/dordogne/thiviers/camping\\\\u002Dle\\\\u002Drepaire\\",\\n    \\"bookable\\": true,\\n    \\"thumb\\": \\"https://media.pitchup.co.uk/images/2/image/upload/t_thumb_v2/v1383148631/camping\\\\u002Dle\\\\u002Drepaire/camping\\\\u002Dle\\\\u002Drepaire\\\\u002Dthe\\\\u002Dpond.jpg\\"\\n}","hierarchy0_exact":"france/","expected_value":6.488E-5,"hosted_online_booking":true,"category_ids":"4,3,10","campsite_id":12273,"parent_hierarchy_name":"Thiviers","content_autocomplete":"Camping le Repaire","rate_count":0,"hierarchy3_exact":"france/aquitaine/dordogne/thiviers/","name_sortable":"CampingleRepaire","available_pitches_tents":false,"category_exact":["tent-pitches","touring-pitches","motorhomes"],"available_pitches_lodges":false,"hierarchy1":"france/aquitaine/","enable_availability":true,"has_tagged_url":false,"available_to_search":true,"path":"france/aquitaine/dordogne/thiviers/camping-le-repaire","available_pitches_motorhomes":false,"hierarchy2_exact":"france/aquitaine/dordogne/","facet_keywords":["is_balance_of_payment_taken_on_arrival","barbecues-allowed","aa-pennant-none","nearby-farmers-market","beach-excellent-water-quality","fishing","recycling-available","outdoor-swimming-pool","tv-room","outdoor-pool-nearby","washing-up-area","dogs-allowed","car-parking-by-pitch","play-area","leisuretheme-park-nearby","public-telephone","on-site-restaurantcafe","peaceful","large-51-200-pitches","tennis-nearby","canoeingkayaking-nearby","cycle-hire-nearby","jumbo-tent-pitches","horse-riding-nearby","cycling-nearby","hard-standings","drainage-hook-up-points-for-tourers","take-away","free-wifi","shower-available","water-hook-up-points-for-tourers","dogs-allowed-all-year","gastronomic-delight","shop-nearby","bar-nearby","beaches","disabled-facilities","electrical-hook-up-points-for-tourers","motorhome-service-point","restaurant-nearby","wifi","bar-or-club-house","book-pitchup","rallies-welcome","family-friendly","launderette","motorcycle-friendly","english","games-room","toilet-block"],"facet_keywords_exact":["is_balance_of_payment_taken_on_arrival","barbecues-allowed","aa-pennant-none","nearby-farmers-market","beach-excellent-water-quality","fishing","recycling-available","outdoor-swimming-pool","tv-room","outdoor-pool-nearby","washing-up-area","dogs-allowed","car-parking-by-pitch","play-area","leisuretheme-park-nearby","public-telephone","on-site-restaurantcafe","peaceful","large-51-200-pitches","tennis-nearby","canoeingkayaking-nearby","cycle-hire-nearby","jumbo-tent-pitches","horse-riding-nearby","cycling-nearby","hard-standings","drainage-hook-up-points-for-tourers","take-away","free-wifi","shower-available","water-hook-up-points-for-tourers","dogs-allowed-all-year","gastronomic-delight","shop-nearby","bar-nearby","beaches","disabled-facilities","electrical-hook-up-points-for-tourers","motorhome-service-point","restaurant-nearby","wifi","bar-or-club-house","book-pitchup","rallies-welcome","family-friendly","launderette","motorcycle-friendly","english","games-room","toilet-block"],"name":"Camping le Repaire","hierarchy1_exact":"france/aquitaine/","available_pitches_caravans":false,"hierarchy_tree":["france/aquitaine/dordogne/thiviers/","france/aquitaine/dordogne/","france/aquitaine/","france/"],"available_pitches_rent_a_tent":false,"has_availability":true,"pitchtype_ids":[3915],"hierarchy0":"france/","hierarchy3":"france/aquitaine/dordogne/thiviers/","hierarchy2":"france/aquitaine/dordogne/","available_pitches_tourers":false,"last_booking_time":"2014-03-08T09:14:53.327Z","api_type":-1,"_version_":1489653176005033984,"score":1.0}]},"error":{"msg":"undefined field: \\"hierarchy4\\"","code":400}}\n'
acdha commented 9 years ago

See #123.