Преобразование строки с пробелом в URL

Я использую таблицу ruby и googles reverse geocode yql для идеальной автоматизации некоторых поисковых запросов. Проблема я попал превращает запрос в формат, юридический адрес. Проблема в том, что кодировка, которую я использую, возвращает незаконные URL-адреса. Запрос я бегу следующим образом

query="select * from google.geocoding where q='40.714224,-73.961452'" 
pQuery= CGI::escape(query)

конечный результат для обработанного запроса выглядит следующим образом

http://query.yahooapis.com/v1/public/yql?q=select+%2A+from+google.geocoding+where+q%3D%2740.3714224%2C--73.961452%27+format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys&callback=

увы, url является незаконным. При проверке того, как выглядит запрос shoud в консоли YQL, я получаю после

http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20google.geocoding%20where%20q%3D%2240.714224%2C-73.961452%22&format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys&callback=

как вы можете надеяться увидеть :), кодировка все неправильно. Мне было интересно, кто-нибудь знает, как я могу генерировать правильные URL-адреса.

1 ответов


Если вы хотите избежать URI, вы должны использовать URI::escape:

require 'uri'

URI.escape("select * from google.geocoding where q='40.714224,-73.961452'")
# => "select%20*%20from%20google.geocoding%20where%20q='40.714224,-73.961452'"