जियोकोडिंग का मतलब आम तौर पर, किसी पते को मैप पर मौजूद जगह में बदलना होता है. इसकी उल्टी प्रोसेस, यानी कि मैप पर मौजूद किसी जगह की जानकारी को ऐसे पते में बदलना जिसे आसानी से पढ़ा जा सके, रिवर्स जियोकोडिंग कहलाती है.
रिवर्स जियोकोडिंग के अनुरोध
ज़रूरी पैरामीटर
latlng
— अक्षांश और देशांतर निर्देशांक. इनसे उस जगह की जानकारी मिलती है जिसके लिए आपको सबसे नज़दीकी और आसानी से पढ़ा जा सकने वाला पता चाहिए.key
— आपके ऐप्लिकेशन का एपीआई पासकोड. इस कुंजी से, कोटा मैनेजमेंट के लिए आपके ऐप्लिकेशन की पहचान होती है. कुंजी पाने का तरीका जानें.
ज़रूरी नहीं पैरामीटर
ये वैकल्पिक पैरामीटर हैं. इन्हें रिवर्स जियोकोडिंग के अनुरोध में शामिल किया जा सकता है:
language
— वह भाषा जिसमें नतीजे दिखाने हैं.- इस्तेमाल की जा सकने वाली भाषाओं की सूची देखें. Google, इस सुविधा के लिए उपलब्ध भाषाओं को अक्सर अपडेट करता रहता है. इसलिए, हो सकता है कि इस सूची में पूरी जानकारी शामिल न हो.
- अगर
language
नहीं दिया जाता है, तो जियोकोडरAccept-Language
हेडर में बताई गई पसंदीदा भाषा का इस्तेमाल करने की कोशिश करता है. इसके अलावा, वह उस डोमेन की मूल भाषा का इस्तेमाल करने की कोशिश करता है जिससे अनुरोध भेजा गया है. - जियोकोडर, सड़क का ऐसा पता देने की पूरी कोशिश करता है जिसे उपयोगकर्ता और स्थानीय लोग, दोनों पढ़ सकें. इस लक्ष्य को पूरा करने के लिए, यह स्थानीय भाषा में सड़क के पते दिखाता है. अगर ज़रूरी हो, तो यह उपयोगकर्ता की पसंदीदा भाषा में पते को लिप्यंतरित भी करता है. अन्य सभी पते, पसंदीदा भाषा में दिखाए जाते हैं. पते के सभी कॉम्पोनेंट, एक ही भाषा में दिखाए जाते हैं. यह भाषा, पहले कॉम्पोनेंट से चुनी जाती है.
- अगर नाम पसंदीदा भाषा में उपलब्ध नहीं है, तो जियोकोडर सबसे मिलते-जुलते नाम का इस्तेमाल करता है.
region
— यह क्षेत्र का कोड है. इसे ccTLD ("टॉप लेवल डोमेन") के तौर पर तय किया जाता है. इसकी वैल्यू दो वर्णों की होती है. लागू कानून के आधार पर, इस पैरामीटर से नतीजों पर भी असर पड़ सकता है.result_type
— एक या उससे ज़्यादा पते के टाइप का फ़िल्टर. इन्हें पाइप (|
) से अलग किया जाता है. अगर पैरामीटर में पते के कई टाइप शामिल हैं, तो एपीआई उन सभी पतों को दिखाता है जो किसी भी टाइप से मेल खाते हैं. प्रोसेसिंग के बारे में जानकारी:result_type
पैरामीटर, खोज को बताए गए पते के टाइप तक सीमित नहीं करता है. इसके बजाय,result_type
खोज के बाद लागू होने वाले फ़िल्टर के तौर पर काम करता है: API, तय किए गएlatlng
के लिए सभी नतीजे फ़ेच करता है. इसके बाद, उन नतीजों को खारिज कर देता है जो तय किए गए पते के टाइप से मेल नहीं खाते. यहां दी गई वैल्यू इस्तेमाल की जा सकती हैं:पते के टाइप और पते के कॉम्पोनेंट के टाइप
जवाब में मौजूद
GeocodeResult
बॉडी में मौजूदtypes
ऐरे, पते का टाइप दिखाता है. पते के टाइप के उदाहरणों में, सड़क का पता, देश या राजनैतिक इकाई शामिल है.GeocodeResult
के मुख्य हिस्से केAddressComponents
फ़ील्ड में मौजूदtypes
कैटगरी से, पते के हर हिस्से के टाइप का पता चलता है. उदाहरण के लिए, सड़क का नंबर या देश.पते कई तरह के हो सकते हैं. इन टाइप को 'टैग' माना जा सकता है. उदाहरण के लिए, कई शहरों को
political
औरlocality
टाइप के हिसाब से टैग किया गया है.ये टाइप इस्तेमाल किए जा सकते हैं और इन्हें पता टाइप और पते के कॉम्पोनेंट टाइप, दोनों ऐरे में दिखाया जाता है:
पते का प्रकार ब्यौरा street_address
मोहल्ले का सटीक पता. route
नाम वाला कोई रास्ता (जैसे, "US 101"). intersection
यह एक बड़ा चौराहा होता है. आम तौर पर, यह दो मुख्य सड़कों का चौराहा होता है. political
कोई राजनीतिक इकाई. आम तौर पर, इस तरह के टाइप से किसी नागरिक प्रशासन के बहुभुज का पता चलता है. country
यह राष्ट्रीय राजनैतिक इकाई होती है. आम तौर पर, यह Geocoder से मिलने वाला सबसे बड़ा ऑर्डर टाइप होता है. administrative_area_level_1
देश के स्तर से नीचे की पहली क्रम की नागरिक इकाई. अमेरिका में, ये प्रशासनिक लेवल राज्य हैं. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. ज़्यादातर मामलों में, administrative_area_level_1
छोटे नाम, ISO 3166-2 के सबडिविज़न और अन्य सूचियों से मिलते-जुलते होंगे. हालांकि, इसकी कोई गारंटी नहीं है, क्योंकि जियोकोडिंग के नतीजे कई तरह के सिग्नल और जगह की जानकारी पर आधारित होते हैं.administrative_area_level_2
देश के स्तर से नीचे की दूसरी श्रेणी की नागरिक इकाई. अमेरिका में, ये प्रशासनिक लेवल काउंटी हैं. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. administrative_area_level_3
यह देश के स्तर से नीचे की तीसरी श्रेणी की सिविल एंटिटी होती है. इस टाइप से, छोटे नागरिक विभाग के बारे में पता चलता है. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. administrative_area_level_4
यह देश के स्तर से नीचे की चौथी श्रेणी की सिविल एंटिटी होती है. इस टाइप से, छोटे नागरिक विभाग के बारे में पता चलता है. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. administrative_area_level_5
यह देश के स्तर से नीचे की पांचवें क्रम की सिविल एंटिटी होती है. इस टाइप से, छोटे नागरिक विभाग के बारे में पता चलता है. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. administrative_area_level_6
देश के स्तर से नीचे की छठी श्रेणी की सिविल एंटिटी. इस टाइप से, छोटे नागरिक विभाग के बारे में पता चलता है. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. administrative_area_level_7
यह देश के स्तर से नीचे की सातवीं श्रेणी की सिविल एंटिटी होती है. इस टाइप से, छोटे नागरिक विभाग के बारे में पता चलता है. सभी देशों में एडमिनिस्ट्रेटिव लेवल नहीं होते. colloquial_area
आम तौर पर इस्तेमाल किया जाने वाला, इकाई का दूसरा नाम. locality
निगमित शहर या टाउन की राजनैतिक इकाई. sublocality
यह किसी इलाके के नीचे आने वाली पहले क्रम की नागरिक इकाई होती है. कुछ जगहों के लिए, आपको इनमें से कोई एक अतिरिक्त टाइप मिल सकता है: sublocality_level_1
सेsublocality_level_5
. उप-स्थानीयता का हर लेवल, एक नागरिक इकाई होता है. ज़्यादा संख्या का मतलब है कि भौगोलिक क्षेत्र छोटा है.neighborhood
आस-पास की जगह का नाम. premise
किसी जगह का नाम, आम तौर पर किसी इमारत या एक ही नाम वाली इमारतों का समूह. subpremise
परिसर के लेवल से नीचे की ऐसी इकाई जिसका पता दिया जा सकता है. जैसे, अपार्टमेंट, यूनिट या सुइट. plus_code
यह अक्षांश और देशांतर से मिला, जगह की जानकारी का एन्कोड किया गया रेफ़रंस होता है. प्लस कोड का इस्तेमाल उन जगहों पर मोहल्ले के पतों की जगह किया जा सकता है जहां वे मौजूद नहीं हैं. जैसे, जहां बिल्डिंग के नंबर नहीं हैं या सड़कों के नाम नहीं हैं. ज़्यादा जानकारी के लिए, https://plus.codes पर जाएं. postal_code
देश में डाक भेजने के लिए इस्तेमाल किया जाने वाला पिन कोड. natural_feature
कोई खास प्राकृतिक जगह. airport
हवाई अड्डा. park
किसी पार्क का नाम. point_of_interest
नाम वाली कोई लोकप्रिय जगह. आम तौर पर, ये "पीओआई" ऐसी स्थानीय इकाइयां होती हैं जिन्हें किसी दूसरी कैटगरी में आसानी से नहीं रखा जा सकता. जैसे, "एम्पायर स्टेट बिल्डिंग" या "एफ़िल टावर". टाइप की खाली सूची से पता चलता है कि पते के इस कॉम्पोनेंट के लिए कोई टाइप नहीं है. उदाहरण के लिए, फ़्रांस में Lieu-dit.
location_type
— एक या उससे ज़्यादा तरह की जगहों का फ़िल्टर. इन्हें पाइप (|
) से अलग किया जाता है. अगर पैरामीटर में कई तरह की जगहें शामिल हैं, तो एपीआई उन सभी पतों को दिखाता है जो किसी भी टाइप से मेल खाते हैं. प्रोसेसिंग के बारे में जानकारी:location_type
पैरामीटर, खोज को बताई गई जगहों के टाइप तक सीमित नहीं करता. इसके बजाय,location_type
खोज के बाद लागू होने वाले फ़िल्टर के तौर पर काम करता है: एपीआई, तय किए गएlatlng
के लिए सभी नतीजे फ़ेच करता है. इसके बाद, उन नतीजों को खारिज कर देता है जो तय किए गए जगह के टाइप से मेल नहीं खाते. ये वैल्यू दिख सकती हैं:"ROOFTOP"
सिर्फ़ उन पतों को दिखाता है जिनके लिए Google के पास, जगह की सटीक जानकारी है. जैसे, गली के पते की सटीक जानकारी."RANGE_INTERPOLATED"
सिर्फ़ ऐसे पते दिखाता है जो दो सटीक पॉइंट (जैसे, चौराहे) के बीच इंटरपोलेट किए गए अनुमानित पते (आम तौर पर सड़क पर) दिखाते हैं. इंटरपोलेट की गई रेंज से आम तौर पर यह पता चलता है कि किसी सड़क के पते के लिए, छत के जियोकोड उपलब्ध नहीं हैं."GEOMETRIC_CENTER"
सिर्फ़ किसी जगह के जियोमेट्रिक सेंटर दिखाता है. जैसे, पॉलीलाइन (उदाहरण के लिए, कोई सड़क) या पॉलीगॉन (क्षेत्र)."APPROXIMATE"
सिर्फ़ उन पतों को दिखाता है जिन्हें अनुमानित पते के तौर पर मार्क किया गया है.
extra_computations
— इस पैरामीटर का इस्तेमाल करके, जवाब में ये अतिरिक्त सुविधाएं शामिल की जा सकती हैं:ADDRESS_DESCRIPTORS
— ज़्यादा जानकारी के लिए, पता बताने वाले शब्द देखें.BUILDING_AND_ENTRANCES
— ज़्यादा जानकारी के लिए, प्रवेश द्वार और बिल्डिंग की आउटलाइन देखें.
extra_computations
पैरामीटर शामिल करें. उदाहरण के लिए:extra_computations=ADDRESS_DESCRIPTORS&extra_computations=BUILDING_AND_ENTRANCES
अगर result_type
और location_type
, दोनों फ़िल्टर मौजूद हैं, तो एपीआई सिर्फ़ वे नतीजे दिखाता है जो result_type
और location_type
, दोनों वैल्यू से मेल खाते हैं. अगर फ़िल्टर की कोई भी वैल्यू स्वीकार नहीं की जाती है, तो एपीआई ZERO_RESULTS
दिखाता है.
रिवर्स जियोकोडिंग का उदाहरण
नीचे दी गई क्वेरी में, ब्रुकलिन की किसी जगह के लिए अक्षांश/देशांतर की वैल्यू शामिल है:
https://maps.googleapis.com/maps/api/geocode/json?latlng=40.714224,-73.961452&key=YOUR_API_KEY
ऊपर दी गई क्वेरी से यह नतीजा मिलता है:
{
"results" : [
{
"address_components" : [
{
"long_name" : "277",
"short_name" : "277",
"types" : [ "street_number" ]
},
{
"long_name" : "Bedford Avenue",
"short_name" : "Bedford Ave",
"types" : [ "route" ]
},
{
"long_name" : "Williamsburg",
"short_name" : "Williamsburg",
"types" : [ "neighborhood", "political" ]
},
{
"long_name" : "Brooklyn",
"short_name" : "Brooklyn",
"types" : [ "sublocality", "political" ]
},
{
"long_name" : "Kings",
"short_name" : "Kings",
"types" : [ "administrative_area_level_2", "political" ]
},
{
"long_name" : "New York",
"short_name" : "NY",
"types" : [ "administrative_area_level_1", "political" ]
},
{
"long_name" : "United States",
"short_name" : "US",
"types" : [ "country", "political" ]
},
{
"long_name" : "11211",
"short_name" : "11211",
"types" : [ "postal_code" ]
}
],
"formatted_address" : "277 Bedford Avenue, Brooklyn, NY 11211, USA",
"geometry" : {
"location" : {
"lat" : 40.714232,
"lng" : -73.9612889
},
"location_type" : "ROOFTOP",
"viewport" : {
"northeast" : {
"lat" : 40.7155809802915,
"lng" : -73.9599399197085
},
"southwest" : {
"lat" : 40.7128830197085,
"lng" : -73.96263788029151
}
}
},
"place_id" : "ChIJd8BlQ2BZwokRAFUEcm_qrcA",
"types" : [ "street_address" ]
},
... Additional <code>results[]</code> ...
ध्यान दें कि रिवर्स जियोकोडर ने एक से ज़्यादा नतीजे दिखाए हैं. "formatted_address"
नतीजे सिर्फ़ डाक पते नहीं होते, बल्कि किसी जगह को भौगोलिक तौर पर नाम देने का कोई भी तरीका होता है. उदाहरण के लिए, शिकागो शहर में किसी पॉइंट को जियोकोड करते समय, जियोकोड किए गए पॉइंट को सड़क के पते, शहर (शिकागो), राज्य (इलिनॉय) या देश (अमेरिका) के तौर पर दिखाया जा सकता है. ये सभी जियोकोडर के लिए "पते" हैं. रिवर्स जियोकोडर, इनमें से किसी भी टाइप को मान्य नतीजे के तौर पर दिखाता है.
रिवर्स जियोकोडर, राजनैतिक इकाइयों (देश, प्रांत, शहर, और मोहल्ले), सड़क के पतों, और पिन कोड से मेल खाता है.
पिछली क्वेरी से मिली formatted_address
वैल्यू की पूरी सूची यहां दी गई है.
{
"plus_code" : {
"compound_code" : "P27Q+MCM New York, NY, USA",
"global_code" : "87G8P27Q+MCM"
},
"results" : [
{
"formatted_address" : "277 Bedford Ave, Brooklyn, NY 11211, USA",
...
"types" : [ "street_address" ]
},
{
"formatted_address" : "279 Bedford Ave, Brooklyn, NY 11211, USA",
...
"types" : [ "premise" ]
},
{
"formatted_address" : "277 Bedford Ave, Brooklyn, NY 11211, USA",
...
"types" : [ "establishment", "point_of_interest" ]
},
{
"formatted_address" : "291-275 Bedford Ave, Brooklyn, NY 11211, USA",
...
"types" : [ "route" ]
},
{
"formatted_address" : "P27Q+MC New York, NY, USA",
...
"types" : [ "plus_code" ]
},
{
"formatted_address" : "South Williamsburg, Brooklyn, NY, USA",
...
"types" : [ "neighborhood", "political" ]
},
{
"formatted_address" : "Brooklyn, NY 11211, USA",
...
"types" : [ "postal_code" ]
},
{
"formatted_address" : "Williamsburg, Brooklyn, NY, USA",
...
"types" : [ "neighborhood", "political" ]
},
{
"formatted_address" : "Kings County, Brooklyn, NY, USA",
...
"types" : [ "administrative_area_level_2", "political" ]
},
{
"formatted_address" : "Brooklyn, NY, USA",
...
"types" : [ "political", "sublocality", "sublocality_level_1" ]
},
{
"formatted_address" : "New York, NY, USA",
...
"types" : [ "locality", "political" ]
},
{
"formatted_address" : "New York, USA",
...
"types" : [ "administrative_area_level_1", "political" ]
},
{
"formatted_address" : "United States",
...
"types" : [ "country", "political" ]
}
],
"status" : "OK"
}
यह एपीआई अलग-अलग तरह के पते दिखाता है. इनमें सबसे सटीक सड़क का पता और कम सटीक राजनैतिक इकाइयां शामिल हैं. जैसे, आस-पास के इलाके, शहर, काउंटी, और राज्य. आम तौर पर, ज़्यादा सटीक पते को सबसे प्रमुख नतीजे के तौर पर दिखाया जाता है. इस मामले में भी ऐसा ही हुआ है. अगर आपको किसी खास तरह के पते से मिलते-जुलते नतीजे चाहिए, तो नतीजों को टाइप के हिसाब से सीमित करना सेक्शन देखें. इस वजह से, नतीजों की जगह एक-दूसरे के हिसाब से अलग-अलग हो सकती है.
टाइप के हिसाब से फ़िल्टर की गई रिवर्स जियोकोडिंग
यहां दिए गए उदाहरण में, दिखाए गए पतों को फ़िल्टर किया गया है. इसमें सिर्फ़ वे पते शामिल हैं जिनका लोकेशन टाइप ROOFTOP
और पता टाइप street_address
है.
https://maps.googleapis.com/maps/api/geocode/json?latlng=40.714224,-73.961452
&location_type=ROOFTOP&result_type=street_address&key=YOUR_API_KEY
ध्यान दें: ये फ़िल्टर सिर्फ़ रिवर्स जियोकोडिंग के लिए मान्य हैं.
रिवर्स जियोकोडिंग के जवाब
रिवर्स जियोकोडिंग के जवाब का फ़ॉर्मैट, जियोकोडिंग के जवाब के फ़ॉर्मैट जैसा ही होता है. जियोकोडिंग के जवाब देखें. यहां रिवर्स जियोकोडिंग के जवाब में मिलने वाले स्टेटस कोड दिए गए हैं.
रिवर्स जियोकोडिंग के स्टेटस कोड
जियोकोडिंग के जवाब वाले ऑब्जेक्ट में मौजूद "status"
फ़ील्ड में, अनुरोध की स्थिति के बारे में जानकारी होती है. इसमें डीबग करने से जुड़ी जानकारी भी हो सकती है. इससे आपको यह पता लगाने में मदद मिलती है कि रिवर्स जियोकोडिंग काम क्यों नहीं कर रही है. "status"
फ़ील्ड में ये वैल्यू हो सकती हैं:
"OK"
से पता चलता है कि कोई गड़बड़ी नहीं हुई है और कम से कम एक पता दिखाया गया है."ZERO_RESULTS"
का मतलब है कि रिवर्स जियोकोडिंग हो गई है, लेकिन कोई नतीजा नहीं मिला. ऐसा तब हो सकता है, जब जियोकोडर को किसी दूसरी जगह काlatlng
पास किया गया हो."OVER_QUERY_LIMIT"
का मतलब है कि आपने तय सीमा से ज़्यादा स्टोरेज का इस्तेमाल किया है."REQUEST_DENIED"
से पता चलता है कि अनुरोध अस्वीकार कर दिया गया है. ऐसा इसलिए हो सकता है, क्योंकि अनुरोध मेंresult_type
याlocation_type
पैरामीटर शामिल है, लेकिन एपीआई पासकोड शामिल नहीं है."INVALID_REQUEST"
आम तौर पर, इनमें से किसी एक वजह से दिखता है:- क्वेरी (
address
,components
याlatlng
) मौजूद नहीं है. - अमान्य
result_type
याlocation_type
दिया गया है.
- क्वेरी (
"UNKNOWN_ERROR"
का मतलब है कि सर्वर की गड़बड़ी की वजह से अनुरोध को प्रोसेस नहीं किया जा सका. फिर से कोशिश करने पर, अनुरोध पूरा हो सकता है.
रिवर्स जियोकोडिंग प्लस कोड
जियोकोडिंग के जवाब में मौजूद plus_code
फ़ील्ड में एक प्लस कोड होता है. यह कोड, क्वेरी किए गए अक्षांश और देशांतर के सबसे करीब होता है.
इसके अलावा, ज़्यादातर मामलों में JSON के नतीजों की कलेक्शन में, जियोकोडिंग का पूरा नतीजा होता है. इसमें plus_code
टाइप और पते में प्लस कोड होता है. डिकोड किए गए प्लस कोड और अनुरोध किए गए पॉइंट के बीच की दूरी, 10 मीटर से कम होगी.