earthengine टूल एक यूटिलिटी प्रोग्राम है. इसकी मदद से, कमांड लाइन से Earth Engine की एसेट और टास्क मैनेज किए जा सकते हैं. Python API इंस्टॉल करने पर, यह अपने-आप इंस्टॉल हो जाता है. यह देखने के लिए कि टूल इंस्टॉल है या नहीं और ठीक से काम कर रहा है या नहीं, कमांड लाइन पर यह लिखें:
earthengine
अगर टूल सही तरीके से इंस्टॉल किया गया है, तो यह उपलब्ध निर्देशों की खास जानकारी प्रिंट करता है. किसी खास निर्देश के बारे में मदद पाने के लिए, इनका इस्तेमाल करें:
earthengine command -h
Python API को पहली बार इंस्टॉल करने पर, आपको यहां बताए गए authenticate कमांड का इस्तेमाल करके साइन इन करना होगा. यहां दिए गए सेक्शन में, उपलब्ध निर्देशों के बारे में ज़्यादा जानकारी दी गई है.
सेवा खाते के क्रेडेंशियल
सेवा खाते के क्रेडेंशियल के साथ सीएलआई का इस्तेमाल करने के लिए, service_account_file फ़्लैग का इस्तेमाल करके, सेवा खाते की कुंजी वाली JSON फ़ाइल पर जाएं.
earthengine --service_account_file=service_account_creds.json
Colab में इस्तेमाल करना
Earth Engine का कमांड-लाइन टूल पहले से इंस्टॉल होता है और Google Colab में इस्तेमाल के लिए तैयार होता है.
पुष्टि करना
हर नए Colab सेशन के लिए पुष्टि करना या अगर वर्चुअल मशीन का इस्तेमाल न करने की वजह से उसकी समयसीमा खत्म हो जाती है (सभी सेशन के लिए क्रेडेंशियल सेव नहीं किए जाते).
पुष्टि करने के फ़्लो को ट्रिगर करने के लिए, Python क्लाइंट लाइब्रेरी इंपोर्ट करें और ee.Authenticate() को कॉल करें. पुष्टि करने के लिए, निर्देशों का पालन करें. Colab में डिफ़ॉल्ट auth_mode colab होता है. अन्य विकल्पों के लिए, पुष्टि करने की गाइड देखें.
import ee
ee.Authenticate()
कमांड लागू करना
Earth Engine CLI जैसी कमांड-लाइन सुविधाओं को चलाने के लिए, आपको कमांड कॉल के पहले विस्मयादिबोधक चिह्न का इस्तेमाल करना होगा.
!earthengine -h
Cloud प्रोजेक्ट सेट करना
हर earthengine कमांड के लिए Cloud प्रोजेक्ट सेट करने के लिए, --project विकल्प का इस्तेमाल करें.
!earthengine --project my-project <command>
इसके अलावा, set_project कमांड का इस्तेमाल करके, सभी earthengine कॉल के लिए डिफ़ॉल्ट प्रोजेक्ट सेट करें. प्रोजेक्ट को क्रेडेंशियल फ़ाइल (~/.config/earthengine/credentials) में जोड़ दिया जाएगा. साथ ही, अगले कमांड के लिए इसका इस्तेमाल किया जाएगा. हालांकि, ऐसा तब तक होगा, जब तक --project
!earthengine set_project my-project
कमांड रेफ़रंस
पुष्टि करें
Earth Engine के लिए, कमांड-लाइन टूल और Python क्लाइंट लाइब्रेरी की पुष्टि करता है. उदाहरण:
earthengine authenticate
Earth Engine, क्लाइंट की पुष्टि करने के लिए OAuth 2.0 प्रोटोकॉल का इस्तेमाल करता है. earthengine authenticate कमांड, आपके वेब ब्राउज़र का इस्तेमाल करके पुष्टि करने की प्रोसेस के लिए, आपसे पूछेगा.
अगर gcloud के डिफ़ॉल्ट पुष्टि मोड का इस्तेमाल किया जा रहा है, तो आपको gcloud इंस्टॉल करना होगा. पुष्टि करने के तरीके से जुड़ी गाइड में, auth_mode पैरामीटर के ज़रिए उपलब्ध पुष्टि करने के अन्य मोड देखें.
acl
Earth Engine एसेट की ऐक्सेस कंट्रोल लिस्ट (एसीएल) को प्रिंट या अपडेट करता है. एएसएल से यह कंट्रोल होता है कि कौनसी एसेट को पढ़ा या उसमें बदलाव किया जा सकता है. उदाहरण:
earthengine acl get projects/my-project/assets/asset_id
earthengine acl set public projects/my-project/assets/asset_id
earthengine acl ch -u username@gmail.com:R projects/my-project/assets/asset_id
get सब-कमांड, एसीएल की जानकारी को JSON फ़ॉर्मैट में प्रिंट करता है. set
सब-कमांड, उसी JSON फ़ॉर्मैट वाली फ़ाइल में दिए गए एसीएल को सेट करता है. get के आउटपुट को सेव करके और set को उपलब्ध कराकर, किसी ऐसेट से दूसरी ऐसेट में एसीएल कॉपी किया जा सकता है.
सेट सब-कमांड में, दो खास ACL नाम भी स्वीकार किए जाते हैं:
private: इससे, प्रॉपर्टी के मालिक को छोड़कर सभी लोगों की अनुमतियां हट जाती हैं.public: सभी उपयोगकर्ताओं को पढ़ने की अनुमति देता है.
ch सब-कमांड की मदद से, एसीएल में अलग-अलग बदलाव किए जा सकते हैं. पढ़ने की अनुमति देने के लिए -u username@gmail.com:R, लिखने की अनुमति देने के लिए -u username@gmail.com:W, और किसी उपयोगकर्ता की अनुमतियां हटाने के लिए -d
username@gmail.com डालें. खास उपयोगकर्ता आइडेंटिफ़ायर AllUsers का इस्तेमाल, सभी उपयोगकर्ताओं को पढ़ने की अनुमति देने या उससे वापस लेने के लिए किया जा सकता है. (ध्यान दें कि AllUsers अनुमतियां वापस लेने से, उन अतिरिक्त अनुमतियों को वापस नहीं लिया जाता है जिन्हें आपने अलग-अलग उपयोगकर्ताओं को दिया हो.)
ऐसेट
Earth Engine ऐसेट से जुड़ा मेटाडेटा प्रिंट करता है या उसे अपडेट करता है. उदाहरण:
earthengine asset info projects/my-project/assets/asset_id
earthengine asset set -p name=value projects/my-project/assets/asset_id
info सब-कमांड, एसेट के बारे में पूरी जानकारी को JSON फ़ॉर्मैट में प्रिंट करता है. इसमें एसेट का मेटाडेटा भी शामिल होता है. set सब-कमांड, किसी ऐसेट पर अलग-अलग मेटाडेटा प्रॉपर्टी सेट करता है.
सेट की गई मेटाडेटा प्रॉपर्टी की वैल्यू, संख्याएं या स्ट्रिंग हो सकती हैं.
--property या -p फ़्लैग का इस्तेमाल करके प्रॉपर्टी के नाम सेट करते समय, प्रॉपर्टी के नाम और वैल्यू को बराबर के निशान से अलग करें. डेटा टाइप का पता अपने-आप चल जाता है. इसके अलावा, प्रॉपर्टी के नाम के आगे (string), (number) या (date) लगाकर, डेटा टाइप की जानकारी साफ़ तौर पर दी जा सकती है. उदाहरण के लिए, यह "42" वैल्यू वाली स्ट्रिंग वैल्यू वाली प्रॉपर्टी सेट करता है:
earthengine asset set -p '(string)name=42' projects/my-project/assets/asset_id
(इस उदाहरण में कोटेशन, शेल को ब्रैकेट का मतलब समझने से रोकते हैं. आपके शेल और प्लैटफ़ॉर्म के हिसाब से, ये ज़रूरी हो सकते हैं या नहीं.)
किसी प्रॉपर्टी को मिटाने के लिए, उसे टाइप के बिना null पर सेट करें:
earthengine asset set -p name=null projects/my-project/assets/asset_id
तारीख की प्रॉपर्टी सिर्फ़ संख्याएं होती हैं.ये Unix epoch (यानी 1 जनवरी, 1970 की मध्यरात्रि) के बाद के मिलीसेकंड की संख्या दिखाती हैं.इन्हें सीधे तौर पर संख्या के तौर पर या इनमें से किसी एक फ़ॉर्मैट में बताया जा सकता है:
YYYY-MM-DD
YYYY-MM-DDThh:mm:ss
YYYY-MM-DDThh:mm:ss.f
टाइम ज़ोन को यूटीसी माना जाता है. --time_start और --time_end फ़्लैग का इस्तेमाल करके, शुरू और खत्म होने के खास समय की प्रॉपर्टी सेट की जा सकती हैं:
earthengine asset set --time_start 1978-10-15T12:34:56 projects/my-project/assets/asset_id
cp
किसी ऐसेट को कॉपी करता है. उदाहरण:
earthengine cp projects/my-project/assets/asset_id projects/my-project/assets/new_asset_id
बनाएं
नए फ़ोल्डर और इमेज कलेक्शन बनाता है. उदाहरण:
earthengine create folder projects/my-project/assets/folder_id
earthengine create collection projects/my-project/assets/collection_id
फ़ोल्डर बनाने के लिए folder सब-कमांड और इमेज कलेक्शन बनाने के लिए collection का इस्तेमाल करें. ज़रूरत के हिसाब से, पैरंट फ़ोल्डर को बार-बार बनाने के लिए, -p विकल्प का इस्तेमाल किया जा सकता है. नए बनाए गए फ़ोल्डर और इमेज के लिए, डिफ़ॉल्ट रूप से निजी एसीएल लागू होते हैं.
ls
एक या उससे ज़्यादा फ़ोल्डर या कलेक्शन के कॉन्टेंट की सूची बनाता है. उदाहरण:
earthengine ls users/username
-l विकल्प, हर ऐसेट के बारे में ज़्यादा जानकारी के साथ लंबे फ़ॉर्मैट का अनुरोध करता है. फ़िलहाल, इसमें सिर्फ़ ऐसेट का टाइप शामिल होता है. सूची में शामिल किए गए हर फ़ोल्डर या कलेक्शन के आइटम की संख्या को सीमित करने के लिए, --max_items number (या कम शब्दों में -m) का इस्तेमाल किया जा सकता है:
earthengine ls -m 10 projects/my-project/assets/my_large_collection
बिना किसी आर्ग्युमेंट के ls कमांड को चलाने पर, वे टॉप लेवल फ़ोल्डर दिखेंगे जिन पर आपका मालिकाना हक है.
मॉडल
TensorFlow के सेव किए गए मॉडल में बदलाव करने के लिए टूल.
model prepare
Earth Engine में इस्तेमाल करने के लिए, सेव किए गए मॉडल को तैयार करना. खास तौर पर, यह आपके SavedModel को Earth Engine से मिले अनुरोधों को प्रोसेस करने के लिए सही फ़ॉर्म में बदल देता है. (SavedModel के बारे में ज़्यादा जानें.)
earthengine model prepare my_source_dir my_dest_dir '{"Conv2D:0":"my_input_band"}' '{"Sigmoid:0":"my_output_band"}'
AI Platform मॉडल के बारे में ज़्यादा जानने के लिए, यहां जाएं. इसका पूरा उदाहरण यहां देखें.
mv
किसी ऐसेट को एक जगह से दूसरी जगह ले जाता है या उसका नाम बदलता है. उदाहरण:
earthengine mv projects/my-project/assets/asset_id projects/my-project/assets/new_asset_id
project_config
प्रोजेक्ट कॉन्फ़िगरेशन की वैल्यू सेट करता है. इस निर्देश का इस्तेमाल करने से पहले, set_project का इस्तेमाल करके कोई प्रोजेक्ट सेट करना न भूलें.
सदस्यता लें
प्रोजेक्ट कॉन्फ़िगरेशन देखने के लिए, get सब-कमांड का इस्तेमाल करें:
earthengine alpha project_config get
अगर आपके पास प्रोजेक्ट के बैच टास्क की सेटिंग देखने की अनुमति है, तो आउटपुट में ये चीज़ें शामिल होती हैं:
maxConcurrentExports: यह एक संख्या है, जो किसी प्रोजेक्ट के लिए, सभी उपयोगकर्ताओं के लिए एक साथ चलने वाले बैच टास्क की ज़्यादा से ज़्यादा संख्या दिखाती है. डिफ़ॉल्ट रूप से, यह उस सदस्यता प्लान के हिसाब से सेट होता है जो उससे जुड़े बिलिंग खाते के लिए तय किया गया है.
इसके अलावा, अगर आपके पास प्लान का कॉन्फ़िगरेशन देखने की अनुमति है, तो आउटपुट में ये चीज़ें शामिल होती हैं:
planMaxConcurrentExports, यह एक संख्या है. इससे पता चलता है कि बिलिंग खाते का इस्तेमाल करने वाले सभी उपयोगकर्ताओं और प्रोजेक्ट के लिए, एक साथ कितने बैच टास्क चलाए जा सकते हैं.
सेट करो
प्रोजेक्ट का कॉन्फ़िगरेशन अपडेट करने के लिए, set सब-कमांड का इस्तेमाल करें. इन सेटिंग को कॉन्फ़िगर किया जा सकता है:
max_concurrent_exports, प्रोजेक्ट के ज़्यादा से ज़्यादा बैच टास्क के पैरलल प्रोसेस को कंट्रोल करने के लिए- के लिए सही अनुमतियां लेना ज़रूरी है
उदाहरण के लिए, किसी प्रोजेक्ट के लिए, एक साथ सिर्फ़ 10 टास्क चलाने की अनुमति देने के लिए, प्रोजेक्ट को कॉन्फ़िगर करने का तरीका:
earthengine alpha project_config set --max_concurrent_exports=10
आउटपुट में, प्रोजेक्ट का अपडेट किया गया कॉन्फ़िगरेशन दिखता है. यह वही कॉन्फ़िगरेशन होता है जो get दिखाता है.
एक साथ कई टास्क करने की सुविधा के बारे में ज़्यादा जानने के लिए, Earth Engine के कोटा पेज पर जाएं.
rm
एक या उससे ज़्यादा ऐसेट मिटाता है. उदाहरण:
earthengine rm projects/my-project/assets/asset_id
earthengine rm -r projects/my-project/assets/folder_id
किसी फ़ोल्डर या कलेक्शन के कॉन्टेंट को बार-बार मिटाने के लिए, -r फ़्लैग का इस्तेमाल किया जा सकता है. एक से ज़्यादा ऐसेट मिटाते समय, सुरक्षा के लिए --dry_run फ़्लैग का इस्तेमाल किया जा सकता है. इससे, यह पुष्टि की जा सकती है कि कौनसी ऐसेट मिटाई जाएंगी.
set_project
वह Google Cloud प्रोजेक्ट सेट करता है जिससे कैलकुलेशन के अनुरोध रूट किए जाते हैं.
earthengine set_project foo-project
जिन कमांड के लिए Cloud की सुविधाओं की ज़रूरत होती है उन्हें चलाने से पहले, यह कमांड ज़रूरी है. जैसे, model.
टास्क
लंबे समय तक चलने वाले टास्क की जानकारी प्रिंट करता है या उन्हें मैनेज करता है. उदाहरण:
earthengine task list
earthengine task list -l
earthengine task info TASK_ID
earthengine task cancel TASK_ID
list सब-कमांड, उन टास्क के बारे में बुनियादी जानकारी दिखाता है जिन्हें आपने हाल ही में सबमिट किया है. -l विकल्प, हर टास्क के बारे में ज़्यादा जानकारी के साथ लंबे फ़ॉर्मैट का अनुरोध करता है. info सब-कमांड, अलग-अलग टास्क के बारे में ज़्यादा जानकारी प्रिंट करता है. cancel सब-कमांड, चल रहे एक या उससे ज़्यादा टास्क को रद्द करता है.
अपलोड करें
Google Cloud Storage से Earth Engine में इमेज या टेबल अपलोड करता है या बाहरी इमेज की मदद से एसेट बनाता है.
इमेज
डिफ़ॉल्ट सेटिंग का इस्तेमाल करके इमेज ऐसेट अपलोड करने के लिए:
earthengine upload image --asset_id=projects/my-project/assets/asset_id gs://bucket/image.tif
अगर एक से ज़्यादा इनपुट इमेज फ़ाइलें दी जाती हैं, तो उन्हें एक इमेज एसेट की टाइल के तौर पर माना जाएगा. Earth Engine में इमेज अपलोड करने के विकल्पों के बारे में ज़्यादा जानने के लिए, इमेज ऐसेट अपलोड करना: बेहतर विकल्प लेख पढ़ें.
--pyramiding_policy
फ़्लैग का इस्तेमाल करके, पिरामिड कम करने की नीति तय की जा सकती है. इसे mean (डिफ़ॉल्ट), sample, mode, min या max में से किसी एक पर सेट किया जा सकता है. इससे यह कंट्रोल होगा कि Earth Engine, आपकी इमेज के कम रिज़ॉल्यूशन वाले वर्शन का पिरामिड कैसे जनरेट करता है:
earthengine upload image --asset_id=projects/my-project/assets/asset_id --pyramiding_policy=sample gs://bucket/image.tif
--last_band_alpha का इस्तेमाल करके यह दिखाया जा सकता है कि इमेज के लिए मास्क, आखिरी बैंड में मौजूद अल्फा चैनल से लिया जाना चाहिए:
earthengine upload image --asset_id=projects/my-project/assets/asset_id --last_band_alpha gs://bucket/image.tif
--nodata_value फ़्लैग का इस्तेमाल करके, कोई डेटा नहीं होने की वैल्यू तय की जा सकती है. इससे इमेज के उन सभी पिक्सल को मास्क कर दिया जाएगा जिनकी वैल्यू, तय की गई वैल्यू से मेल खाती है:
earthengine upload image --asset_id=users/myuser/asset --nodata_value=255 gs://bucket/image.tif
ऐसे ही फ़्लैग का इस्तेमाल करके, एसेट पर सेट करने के लिए मेटाडेटा प्रॉपर्टी भी तय की जा सकती हैं. ये फ़्लैग, ऊपर बताए गए asset set कमांड के साथ काम करते हैं.
इन विकल्पों के बारे में, इमेज मेनिफ़ेस्ट की गाइड में भी बताया गया है.
टेबल
Google Cloud Storage से Earth Engine टेबल ऐसेट में शेपफ़ाइल, CSV या TFRecord अपलोड करने के लिए, इनमें से किसी भी तरीके का इस्तेमाल किया जा सकता है:
earthengine upload table --asset_id=projects/my-project/assets/myUploadedShapefile gs://bucket/foo.shp
earthengine upload table --asset_id=projects/my-project/assets/myUploadedCSV gs://bucket/foo.csv
earthengine upload table --asset_id=projects/my-project/assets/myUploadedTFRecord gs://bucket/foo.tfrecord
CSV और TFRecord फ़ाइलों को समझने के कई तरीके हैं. टेबल अपलोड करने के विकल्पों की पूरी सूची देखने के लिए, टेबल मेनिफ़ेस्ट गाइड पर जाएं या इनमें से कोई तरीका अपनाएं:
earthengine upload table -h
external_image
किसी बाहरी इमेज की मदद से ऐसेट बनाने के लिए, upload_image कमांड को किसी मेनिफ़ेस्ट के साथ चलाएं:
earthengine alpha upload external_image --manifest /tmp/foo.json
मेनिफ़ेस्ट का एक उदाहरण:
{
"name": "projects/{project}/assets/cogdemo1",
"tilesets": [
{ "id": "0", "sources": [{ "uris": ["gs://ee-docs-demos/COG_demo.tif"] }] }
],
"properties": {
"source": "https://code.earthengine.google.com/d541cf8b268b2f9d8f834c255698201d"
},
"startTime": "2016-01-01T00:00:00.000000000Z",
"endTime": "2016-12-31T15:01:23.000000000Z"
}
मेनिफ़ेस्ट बनाने के बारे में ज़्यादा जानकारी के लिए, Cloud GeoTIFF गाइड और इमेज मेनिफ़ेस्ट गाइड देखें.