{"id":2151,"date":"2021-12-17T22:44:07","date_gmt":"2021-12-17T19:44:07","guid":{"rendered":"https:\/\/1.cbm.ua\/?p=2151"},"modified":"2024-07-21T12:52:22","modified_gmt":"2024-07-21T09:52:22","slug":"%d0%bd%d0%b0%d1%87%d0%b8%d0%bd%d0%b0%d0%b5%d0%bc-%d1%80%d0%b0%d0%b1%d0%be%d1%82%d1%83-%d1%81-google-sheets-%d0%bd%d0%b0-python-%d0%be%d1%82-%d1%80%d0%b5%d0%b3%d0%b8%d1%81%d1%82%d1%80%d0%b0%d1%86","status":"publish","type":"post","link":"http:\/\/1.cbm.ua\/?p=2151","title":{"rendered":"\u2764\ufe0f ___ \u041d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 Google Sheets (Google \u0422\u0430\u0431\u043b\u0438\u0446\u044b) \u043d\u0430 Python. \u041e\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0434\u043e \u0447\u0442\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445. (spreadsheets \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439; docs.google.com)"},"content":{"rendered":"<div class=\"wp-block-post-date\"><time datetime=\"2021-12-17T22:44:07+03:00\">2021-12-17<\/time><\/div>\n\n\n<p><a href=\"https:\/\/habr.com\/ru\/post\/483302\/\" data-type=\"URL\" data-id=\"https:\/\/habr.com\/ru\/post\/483302\/\" target=\"_blank\" rel=\"noreferrer noopener\">URL \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a<\/a><\/p>\n\n\n\n<h1 class=\"wp-block-heading\">\u041d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 Google Sheets (Google \u0422\u0430\u0431\u043b\u0438\u0446\u044b) \u043d\u0430 Python. \u041e\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0434\u043e \u0447\u0442\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445<\/h1>\n\n\n\n<p><a href=\"https:\/\/habr.com\/ru\/hub\/python\/\">Python&nbsp;*<\/a><a href=\"https:\/\/habr.com\/ru\/hub\/google_api\/\">Google API&nbsp;*<\/a>\u0418\u0437 \u043f\u0435\u0441\u043e\u0447\u043d\u0438\u0446\u044b\u0414\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0434\u043e\u043b\u0433\u043e \u044f \u043e\u0431\u0445\u043e\u0434\u0438\u043b\u0441\u044f \u0432\u044b\u0433\u0440\u0443\u0437\u043a\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 Excel, \u043d\u043e \u043c\u043e\u0434\u0430 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f, \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0445\u043e\u0442\u044f\u0442 \u0432 \u043e\u0431\u043b\u0430\u043a\u0430.<\/p>\n\n\n\n<p>\u041d\u0430\u0447\u0430\u0432 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u044c \u0440\u044f\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 Python, \u0440\u0435\u0448\u0438\u043b, \u0447\u0442\u043e \u0441\u0430\u043c\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0441\u043c\u0435\u043d\u0438\u0442\u044c (\u0438\u043b\u0438 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u044c) Excel \u0447\u0435\u043c-\u0442\u043e \u0431\u043e\u043b\u0435\u0435 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u043c.<\/p>\n\n\n\n<p>\u041a\u043e\u0433\u0434\u0430 \u044f \u0432\u043f\u0435\u0440\u0432\u044b\u0435 \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0441\u044f \u0441 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c\u044e \u0440\u0430\u0431\u043e\u0442\u044b c \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 Google \u0438\u0437 Python, \u0442\u043e \u043f\u0440\u0435\u0431\u044b\u0432\u0430\u043b \u0432 \u0438\u043b\u043b\u044e\u0437\u0438\u0438, \u0447\u0442\u043e \u0432\u0441\u0435 \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432 \u043f\u0430\u0440\u0443 \u043a\u043b\u0438\u043a\u043e\u0432. \u0420\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043e\u043a\u0430\u0437\u0430\u043b\u0430\u0441\u044c \u043c\u0435\u043d\u0435\u0435 \u0440\u0430\u0434\u0443\u0436\u043d\u043e\u0439, \u043d\u043e \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u0433\u043b\u043e\u0431\u0443\u0441\u0430 \u0443 \u043d\u0430\u0441 \u043d\u0435\u0442.<\/p>\n\n\n\n<p>\u041c\u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043c\u043e\u0433\u043b\u0438 \u0441\u0442\u0430\u0442\u044c\u0438:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><a href=\"https:\/\/habr.com\/ru\/post\/305378\">\u0413\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u043c \u043a\u0440\u0430\u0441\u0438\u0432\u0443\u044e Google-\u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0438\u0437 \u0441\u0432\u043e\u0435\u0439 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b (\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f Google Sheets API v4)<\/a><\/li>\n\n\n\n<li><a href=\"http:\/\/italylov.ru\/blog\/all\/probuem-rabotat-s-google-sheets-api\/\">\u041d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 Google Sheets API v4\/<\/a><\/li>\n\n\n\n<li><a href=\"http:\/\/datalytics.ru\/all\/rabotaem-s-api-google-drive-s-pomoschyu-python\/\">\u0420\u0430\u0431\u043e\u0442\u0430\u0435\u043c \u0441 API Google Drive \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Python<\/a><\/li>\n<\/ul>\n\n\n\n<p>\u041a\u0430\u043a \u043e\u0431\u044b\u0447\u043d\u043e \u2013 \u043a\u043e\u0433\u0434\u0430 \u0432\u043f\u0435\u0440\u0432\u044b\u0435 \u0437\u0430 \u0447\u0442\u043e-\u0442\u043e \u0431\u0435\u0440\u0435\u0448\u044c\u0441\u044f, \u0442\u043e \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u0435\u0448\u044c\u0441\u044f \u0441 \u043c\u0430\u0441\u0441\u043e\u0439 \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0442 \u043b\u0438\u0448\u044c \u043d\u0435\u0434\u043e\u0443\u043c\u0435\u043d\u0438\u0435 \u2013 \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u043e\u0431 \u044d\u0442\u043e\u043c \u0432\u043e\u043e\u0431\u0449\u0435 \u0437\u0430\u0434\u0443\u043c\u044b\u0432\u0430\u0442\u044c\u0441\u044f. \u042d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0440\u043d\u043e \u0436\u0435!<\/p>\n\n\n\n<p>\u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u044f \u043f\u0440\u043e\u0441\u0442\u043e \u0448\u0435\u043b \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u043f\u0443\u0442\u0435\u043c \u2013 \u0431\u0443\u0434\u0443 \u0440\u0430\u0434, \u0435\u0441\u043b\u0438 \u0432\u044b \u043c\u0435\u043d\u044f \u043f\u043e\u043f\u0440\u0430\u0432\u0438\u0442\u0435.<\/p>\n\n\n\n<p>\u0412\u0441\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u043b\u0438\u0441\u044c \u043d\u0430 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0435 \u0441 Windows + Python 3.6.6, \u0442\u0430\u043a\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0441\u044f Jupyter Notebook.<\/p>\n\n\n\n<p>\u041e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0442\u0440\u0443\u0434\u043d\u043e\u0441\u0442\u0438 \u0443 \u043c\u0435\u043d\u044f \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u043b\u0438 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043f\u0440\u0435\u0434\u0432\u0430\u0440\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a. \u041d\u0430\u0439\u0442\u0438 \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u044b\u0439 \u043a\u043e\u0434 \u043d\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043e\u0441\u043e\u0431\u043e\u0433\u043e \u0442\u0440\u0443\u0434\u0430.<\/p>\n\n\n\n<p>\u041a\u043e\u0434, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0432 \u0441\u0442\u0430\u0442\u044c\u0435, \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d&nbsp;<a href=\"https:\/\/github.com\/ovkgit\/google_sheets_python\">\u0432 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438<\/a><br><a><\/a><\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u0420\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f \u0432 \u0441\u0435\u0440\u0432\u0438\u0441\u0430\u0445 Google \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a.<\/h2>\n\n\n\n<p>\u0414\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 \u043d\u0443\u0436\u043d\u043e \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 Google, \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442 \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n\n\n\n<p><a href=\"https:\/\/developers.google.com\/sheets\/\">\u041e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f \u043d\u0430 \u0430\u043d\u0433\u043b\u0438\u0439\u0441\u043a\u043e\u043c \u044f\u0437\u044b\u043a\u0435 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0437\u0434\u0435\u0441\u044c<\/a>.<\/p>\n\n\n\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0443\u0436\u043d\u043e \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 gmail.com (\u044d\u0442\u043e \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e). \u041f\u043e\u0442\u043e\u043c \u043d\u0443\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442 (\u0442\u0430\u043a Google \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0441\u0432\u043e\u0438\u043c \u0441\u0435\u0440\u0432\u0438\u0441\u0430\u043c).<\/p>\n\n\n\n<p>\u042d\u0442\u043e \u0434\u043e\u043b\u0433\u0438\u0439 \u0438 \u043d\u0443\u0434\u043d\u044b\u0439 \u043f\u0440\u043e\u0446\u0435\u0441\u0441, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u043e\u043d\u044f\u0442\u044c, \u043f\u043e\u0447\u0435\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u044b \u043e\u0442 Google \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u043d\u0435 \u0441\u0430\u043c\u044b\u043c\u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u043c\u0438 \u0438 \u0438\u043d\u0442\u0443\u0438\u0442\u0438\u0432\u043d\u043e \u043f\u043e\u043d\u044f\u0442\u043d\u044b\u043c\u0438 (\u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441\u0447\u0438\u0442\u0430\u044e\u0442, \u0447\u0442\u043e \u0441\u043e\u0446\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0435\u0442\u044c Google+ \u043d\u0435 \u0432\u0437\u043b\u0435\u0442\u0435\u043b\u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u043f\u043e \u044d\u0442\u043e\u0439 \u043f\u0440\u0438\u0447\u0438\u043d\u0435).<\/p>\n\n\n\n<p>\u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0437\u0430\u0439\u0434\u0438\u0442\u0435 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443&nbsp;<a href=\"https:\/\/console.developers.google.com\/cloud-resource-manager\">console.developers.google.com\/cloud-resource-manager<\/a>&nbsp;\u0438 \u043d\u0430\u0436\u0430\u0442\u044c \u00ab\u0421\u043e\u0437\u0434\u0430\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/fi\/-w\/y6\/fi-wy693xsw54m-xh7jnh-17ble.jpeg\"><\/p>\n\n\n\n<p>\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0438\u043c\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0438 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0421\u043e\u0437\u0434\u0430\u0442\u044c\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/pq\/li\/wq\/pqliwqiudct5g7s6q_rm6iag6tw.jpeg\"><\/p>\n\n\n\n<p>\u0412 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u043e\u043c \u0441\u043f\u0438\u0441\u043a\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0437\u0430\u0439\u0434\u0438\u0442\u0435 \u0432 \u043c\u0435\u043d\u044e \u00ab\u041f\u0440\u0430\u0432\u0430 \u0434\u043e\u0441\u0442\u0443\u043f\u0430\u00bb<br><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/3z\/pr\/yb\/3zprybr3paa7eqi5sxsurdt_aq8.jpeg\"><\/p>\n\n\n\n<p>\u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0414\u043e\u0431\u0430\u0432\u0438\u0442\u044c\u00bb, \u0432\u043d\u0435\u0441\u0438\u0442\u0435 \u0441\u0432\u043e\u0439 email \u0441 \u0434\u043e\u043c\u0435\u043d\u0430 gmail.com \u0438 \u0432\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u0433\u0440\u0443\u043f\u043f\u0443 \u00ab\u041f\u0440\u043e\u0435\u043a\u0442\u00bb \u2014 \u00ab\u0412\u043b\u0430\u0434\u0435\u043b\u0435\u0446\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/fu\/4a\/cl\/fu4aclu3gibqg8-1rae94sovf08.jpeg\"><\/p>\n\n\n\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f.<\/p>\n\n\n\n<p>\u041c\u043e\u0436\u0435\u0442 \u043f\u043e\u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u0441\u0442\u0440\u0430\u043d\u043d\u044b\u043c, \u0447\u0442\u043e \u0432\u044b \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u043f\u0440\u043e\u0435\u043a\u0442 \u043d\u043e \u0432\u044b\u043d\u0443\u0436\u0434\u0435\u043d\u044b \u0441\u0430\u043c\u0438 \u0441\u0435\u0431\u0435 \u0432\u044b\u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0430. \u0418 \u044d\u0442\u043e \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0441\u0442\u0440\u0430\u043d\u043d\u043e, \u043d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0442\u0430\u043a\u043e\u0439 \u043f\u0443\u0442\u044c \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0440\u043e\u0439\u0442\u0438 \u043d\u0430 \u043c\u043e\u043c\u0435\u043d\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u044d\u0442\u043e\u0433\u043e \u043a\u0443\u0440\u0441\u0430, \u0447\u0442\u043e\u0431\u044b \u0432\u0441\u0435 \u043d\u0430\u0447\u0430\u043b\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043a\u0430\u043a \u043d\u0430\u0434\u043e.<\/p>\n\n\n\n<p>\u0421\u043d\u043e\u0432\u0430 \u0437\u0430\u0439\u0434\u0438\u0442\u0435 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443&nbsp;<a href=\"https:\/\/console.developers.google.com\/cloud-resource-manager\">console.developers.google.com\/cloud-resource-manager<\/a><\/p>\n\n\n\n<p>\u0412\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u043d\u0430 \u0441\u0432\u043e\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043c\u0435\u043d\u044e \u00ab\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/_p\/dx\/al\/_pdxalr_zhciudnkssxnej4iybo.jpeg\"><\/p>\n\n\n\n<p>\u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u0432\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u00ab\u0421\u0435\u0440\u0432\u0438\u0441\u043d\u044b\u0435 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u044b\u00bb, \u0430 \u0437\u0430\u0442\u0435\u043c \u00ab\u0421\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u0435\u0440\u0432\u0438\u0441\u043d\u044b\u0439 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/8e\/ss\/t-\/8esst-mi2_3ioiylkv5ej1itpxu.jpeg\"><\/p>\n\n\n\n<p>\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0430 \u0438 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0421\u043e\u0437\u0434\u0430\u0442\u044c\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/4h\/fe\/18\/4hfe18ts9ywn44bevocl3-fpsue.jpeg\"><\/p>\n\n\n\n<p>\u0412\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u0440\u043e\u043b\u044c \u00ab\u0412\u043b\u0430\u0434\u0435\u043b\u0435\u0446\u00bb \u0438 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u041f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u044c\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/0x\/d9\/sx\/0xd9sxloeigykugl41pdx_qgp64.jpeg\"><\/p>\n\n\n\n<p>\u0412 \u043f\u043e\u044f\u0432\u0438\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0421\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043b\u044e\u0447\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/pv\/jc\/xk\/pvjcxkvp6mjwda30w3uorjkbex4.jpeg\"><\/p>\n\n\n\n<p>\u0412\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u0442\u0438\u043f \u043a\u043b\u044e\u0447\u0430 \u00abjson\u00bb \u0438 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0421\u043e\u0437\u0434\u0430\u0442\u044c\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/75\/sz\/3l\/75sz3lffo7nr8119jrpu-vvm1i8.jpeg\"><\/p>\n\n\n\n<p>\u0411\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u043d \u0438 \u0441\u0440\u0430\u0437\u0443 \u0436\u0435 \u0441\u043a\u0430\u0447\u0430\u043d \u0444\u0430\u0439\u043b \u0441 \u043a\u043b\u044e\u0447\u0430\u043c\u0438. \u0421\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0435 \u0435\u0433\u043e, \u0438\u043c\u0435\u043d\u043d\u043e \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0435\u043c\u0443 \u043c\u044b \u0441\u043c\u043e\u0436\u0435\u043c \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0441\u0435\u0440\u0432\u0438\u0441\u0430\u043c Google.<\/p>\n\n\n\n<p>\u041d\u0430\u0436\u043c\u0438\u0442\u0435 \u043d\u0430 \u043a\u043d\u043e\u043f\u043a\u0443 \u0441 \u0442\u0440\u0435\u043c\u044f \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u0448\u0442\u0440\u0438\u0445\u0430\u043c\u0438, \u0441\u043b\u0435\u0432\u0430 \u043e\u0442 \u043d\u0430\u0434\u043f\u0438\u0441\u0438 \u00abGoogle APIs\u00bb, \u0432\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u043f\u0443\u043d\u043a\u0442 \u00abAPI \u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u044b\u00bb, \u0430 \u0432 \u043d\u0435\u043c \u043f\u043e\u0434\u043f\u0443\u043d\u043a\u0442 \u00ab\u041f\u0430\u043d\u0435\u043b\u044c \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f\u00bb.<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/n9\/0c\/gh\/n90cgh2hyrqigsxjus02cwhrt-c.jpeg\"><\/p>\n\n\n\n<p>\u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u044c API \u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u044b\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/w8\/3f\/wc\/w83fwcm2h2zcq4qza3pysyjhseu.jpeg\"><\/p>\n\n\n\n<p>\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0432 \u0441\u0442\u0440\u043e\u043a\u0443 \u043f\u043e\u0438\u0441\u043a\u0430 \u00abgoogle drive\u00bb \u0438 \u043a\u043b\u0438\u043a\u043d\u0438\u0442\u0435 \u043d\u0430 \u0441\u0435\u0440\u0432\u0438\u0441\u0435 \u00abGoogle Drive API\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/fj\/ks\/iw\/fjksiwvxazgd-6erfruqwrwq8os.jpeg\"><\/p>\n\n\n\n<p>\u041d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/jk\/f-\/ys\/jkf-ysfiu--oqojyf8vi1lwphao.jpeg\"><\/p>\n\n\n\n<p>\u0421\u0430\u0439\u0442 \u0443\u0432\u0435\u0434\u043e\u043c\u0438\u0442 \u0432\u0430\u0441, \u0447\u0442\u043e API \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u043e \u0438 \u043f\u0440\u0435\u0434\u0443\u043f\u0440\u0435\u0434\u0438\u0442, \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0443\u0447\u0435\u0442\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435. \u0418\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u0439\u0442\u0435 \u044d\u0442\u043e \u043f\u0440\u0435\u0434\u0443\u043f\u0440\u0435\u0436\u0434\u0435\u043d\u0438\u0435 (\u0432\u0435\u0434\u044c \u043c\u044b \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u043d\u044b\u0439 \u0430\u043a\u043a\u0430\u0443\u043d\u0442).<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/se\/e4\/z4\/see4z4tacpn3manmkn_tixgkgck.jpeg\"><\/p>\n\n\n\n<p>\u0421\u043d\u043e\u0432\u0430 \u0437\u0430\u0445\u043e\u0434\u0438\u0442\u0435 \u0432 \u043f\u0430\u043d\u0435\u043b\u044c \u0443\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/c0\/ak\/ln\/c0aklnjxew9zwlph6fgp1ym-yt8.jpeg\"><\/p>\n\n\n\n<p>\u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 \u00ab\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u044c API \u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u044b\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/w8\/3f\/wc\/w83fwcm2h2zcq4qza3pysyjhseu.jpeg\"><\/p>\n\n\n\n<p>\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0432 \u0441\u0442\u0440\u043e\u043a\u0443 \u043f\u043e\u0438\u0441\u043a\u0430 \u00absheet\u00bb \u0438 \u043a\u043b\u0438\u043a\u043d\u0438\u0442\u0435 \u043d\u0430 \u0441\u0435\u0440\u0432\u0438\u0441\u0435 \u00abGoogle Sheets API\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habr.com\/ru\/post\/483302\/null\" alt=\"\u0418\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u043d\u0435 \u0437\u0430\u0433\u0440\u0443\u0436\u0435\u043d\u043e\"><\/p>\n\n\n\n<p>\u0423\u0431\u0435\u0434\u0438\u0442\u0435\u0441\u044c, \u0447\u0442\u043e \u044d\u0442\u043e API \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043e. \u041e\u043d\u043e \u0434\u043e\u043b\u0436\u043d\u043e \u0432\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u0441\u044f \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u043f\u0440\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0438 Google Drive API. \u0415\u0441\u043b\u0438 \u043e\u043d\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043e, \u0432\u044b \u0443\u0432\u0438\u0434\u0438\u0442\u0435 \u043a\u043d\u043e\u043f\u043a\u0443 \u00ab\u0423\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 API\u00bb, \u0435\u0441\u043b\u0438 \u043d\u0435\u0442 \u2014 \u043a\u043d\u043e\u043f\u043a\u0443 \u00ab\u0412\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u00bb. \u0412\u043a\u043b\u044e\u0447\u0438\u0442\u0435 \u0435\u0433\u043e, \u043f\u0440\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438.<\/p>\n\n\n\n<p>\u0412 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0440\u0430\u0437 \u0437\u0430\u0439\u0434\u0438\u0442\u0435 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443&nbsp;<a href=\"https:\/\/console.developers.google.com\/cloud-resource-manager\">console.developers.google.com\/cloud-resource-manager<\/a><\/p>\n\n\n\n<p>\u0412\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u043d\u0430 \u0441\u0432\u043e\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043c\u0435\u043d\u044e \u00ab\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/ov\/ue\/i6\/ovuei6xocepbhtqmgs8ydb9tbt4.jpeg\"><br>\u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u0432\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u00ab\u0421\u0435\u0440\u0432\u0438\u0441\u043d\u044b\u0435 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u044b\u00bb, \u0430 \u0437\u0430\u0442\u0435\u043c \u0441\u043a\u043e\u043f\u0438\u0440\u0443\u0439\u0442\u0435 \u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0435 email \u0441\u0435\u0440\u0432\u0438\u0441\u043d\u043e\u0433\u043e \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0430. \u041e\u043d \u043f\u0440\u0438\u0433\u043e\u0434\u0438\u0442\u0441\u044f \u0432\u0430\u043c, \u0447\u0442\u043e\u0431\u044b \u0432\u044b\u0434\u0430\u0432\u0430\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c.<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/qh\/p5\/yr\/qhp5yrn74itkqnbwkvtstlcjwha.jpeg\"><\/p>\n\n\n\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u043a \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a. \u0412\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u0435 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u043a\u043e\u043c\u0430\u043d\u0434\u0443<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">pip3 install --upgrade google-api-python-client<\/pre>\n\n\n\n<p>\u0430 \u0437\u0430\u0442\u0435\u043c<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">pip3 install oauth2client<\/pre>\n\n\n\n<p>\u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0447\u0442\u043e \u043f\u0440\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0435 \u0432\u0442\u043e\u0440\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0432\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0435 \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u0435, \u0447\u0442\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 oauth2client \u0443\u0436\u0435 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0430.<\/p>\n\n\n\n<p>\u0417\u0430\u0439\u0434\u0438\u0442\u0435 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443&nbsp;<a href=\"https:\/\/raw.githubusercontent.com\/gsuitedevs\/python-samples\/master\/sheets\/quickstart\/quickstart.py\">raw.githubusercontent.com\/gsuitedevs\/python-samples\/master\/sheets\/quickstart\/quickstart.py<\/a><\/p>\n\n\n\n<p>\u041d\u0430\u0436\u043c\u0438\u0442\u0435 \u043f\u0440\u0430\u0432\u0443\u044e \u043a\u043d\u043e\u043f\u043a\u0443 \u043c\u044b\u0448\u043a\u0438 \u0438 \u0432\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u00ab\u0421\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u044c \u043a\u0430\u043a\u00bb<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/t7\/z5\/mv\/t7z5mvudm8lmipgvbcxsjn6jsr4.jpeg\"><\/p>\n\n\n\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0435 \u0444\u0430\u0439\u043b \u043f\u043e\u0434 \u0438\u043c\u0435\u043d\u0435\u043c quickstart.py<\/p>\n\n\n\n<p>\u0438 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u0435 \u0435\u0433\u043e \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">python quickstart.py<\/pre>\n\n\n\n<p>\u041e\u0442\u043a\u0440\u043e\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 (\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u043e\u043d \u0441\u043a\u0430\u0436\u0435\u0442, \u0447\u0442\u043e \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430 \u043d\u0435\u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u0430\u044f, \u043d\u043e \u0441\u043c\u0435\u043b\u043e \u0438\u0434\u0438\u0442\u0435 \u0432\u043f\u0435\u0440\u0435\u0434) \u0438 \u0432\u0430\u043c \u043d\u0430\u0434\u043e \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0438\u043d\u044f\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u0438\u044f.<\/p>\n\n\n\n<p>\u041d\u0430 \u044d\u0442\u043e\u043c \u043d\u0430\u0448 \u043f\u0443\u0442\u044c \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u0417\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0438 \u0444\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/h2>\n\n\n\n<p>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043f\u0435\u0440\u0432\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438\nimport httplib2 \nimport apiclient.discovery\nfrom oauth2client.service_account import ServiceAccountCredentials\t\n\nCREDENTIALS_FILE = 'seraphic-effect-248407-7ac2c44ec709.json'  # \u0418\u043c\u044f \u0444\u0430\u0439\u043b\u0430 \u0441 \u0437\u0430\u043a\u0440\u044b\u0442\u044b\u043c \u043a\u043b\u044e\u0447\u043e\u043c, \u0432\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0441\u0432\u043e\u0435\n\n# \u0427\u0438\u0442\u0430\u0435\u043c \u043a\u043b\u044e\u0447\u0438 \u0438\u0437 \u0444\u0430\u0439\u043b\u0430\ncredentials = ServiceAccountCredentials.from_json_keyfile_name(CREDENTIALS_FILE, ['https:\/\/www.googleapis.com\/auth\/spreadsheets', 'https:\/\/www.googleapis.com\/auth\/drive'])\n\nhttpAuth = credentials.authorize(httplib2.Http()) # \u0410\u0432\u0442\u043e\u0440\u0438\u0437\u0443\u0435\u043c\u0441\u044f \u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u0435\nservice = apiclient.discovery.build('sheets', 'v4', http = httpAuth) # \u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 \u0438 4 \u0432\u0435\u0440\u0441\u0438\u044e API \n\nspreadsheet = service.spreadsheets().create(body = {\n    'properties': {'title': '\u041f\u0435\u0440\u0432\u044b\u0439 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442', 'locale': 'ru_RU'},\n    'sheets': [{'properties': {'sheetType': 'GRID',\n                               'sheetId': 0,\n                               'title': '\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d',\n                               'gridProperties': {'rowCount': 100, 'columnCount': 15}}}]\n}).execute()\nspreadsheetId = spreadsheet['spreadsheetId'] # \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 \u0444\u0430\u0439\u043b\u0430\nprint('https:\/\/docs.google.com\/spreadsheets\/d\/' + spreadsheetId)\n<\/pre>\n\n\n\n<p>\u0415\u0441\u043b\u0438 \u0432\u0441\u0435 \u043f\u0440\u043e\u0448\u043b\u043e \u0431\u0435\u0437 \u043e\u0448\u0438\u0431\u043e\u043a \u2014 \u043d\u0430 \u044d\u043a\u0440\u0430\u043d \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0432\u0435\u0434\u0435\u043d\u0430 \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u0443.<\/p>\n\n\n\n<p>\u0412 \u044d\u0442\u043e\u0439 \u0441\u0441\u044b\u043b\u043a\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 \u0444\u0430\u0439\u043b\u0430, \u043c\u044b \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u0435\u0433\u043e \u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 spreadsheetId \u0438 \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0432 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u043c.<\/p>\n\n\n\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u0435 \u043f\u043e \u043d\u0435\u0439. Google \u0441\u043e\u043e\u0431\u0449\u0438\u0442 \u0432\u0430\u043c, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u043d\u0435\u0442 \u0434\u043e\u0441\u0442\u0443\u043f\u0430<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/y0\/n7\/te\/y0n7te-mweqjhzr_9eg0gqsj50q.jpeg\"><\/p>\n\n\n\n<p>\u041d\u0435 \u0437\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0439\u0442\u0435 \u0440\u0430\u0437\u0440\u0435\u0448\u0435\u043d\u0438\u0435! \u0412\u0430\u043c \u043f\u0440\u0438\u0434\u0435\u0442 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0435, \u0447\u0442\u043e \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u0434\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043f\u0438\u0441\u044c\u043c\u043e \u0441 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c \u043d\u0430 \u0430\u0434\u0440\u0435\u0441, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u0430\u043c Google \u043d\u0430\u0437\u043d\u0430\u0447\u0438\u043b \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u043e\u043c\u0443 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0443. \u0410 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u044d\u0442\u043e\u0442 \u0430\u0434\u0440\u0435\u0441 \u043d\u0435\u043b\u044c\u0437\u044f. \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u044d\u0442\u043e \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0431\u0435\u0441\u043f\u043b\u0430\u0442\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435.<\/p>\n\n\n\n<p>\u041d\u043e \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0432\u044b\u0434\u0430\u0442\u044c \u0441\u0435\u0431\u0435 \u0434\u043e\u0441\u0442\u0443\u043f \u0447\u0435\u0440\u0435\u0437 Google Drive. \u0412\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u0430\u0434\u0440\u0435\u0441 my_test_address@gmail.com \u043d\u0430 \u0441\u0432\u043e\u0439.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">driveService = apiclient.discovery.build('drive', 'v3', http = httpAuth) # \u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 Google Drive \u0438 3 \u0432\u0435\u0440\u0441\u0438\u044e API\naccess = driveService.permissions().create(\n    fileId = spreadsheetId,\n    body = {'type': 'user', 'role': 'writer', 'emailAddress': 'my_test_address@gmail.com'},  # \u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u0434\u043e\u0441\u0442\u0443\u043f \u043d\u0430 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\n    fields = 'id'\n).execute()<\/pre>\n\n\n\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f, \u043d\u0435 \u0437\u0430\u043a\u0440\u044b\u0432\u0430\u0439\u0442\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c \u0435\u044e \u0438 \u0441\u0440\u0430\u0437\u0443 \u0436\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f.<\/p>\n\n\n\n<p>\u0423 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430 \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0439 \u043a\u043e\u0434 \u2014 spreadsheetId \u2014 \u0438\u043c\u0435\u043d\u043d\u043e \u043e\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u0432 \u0430\u0434\u0440\u0435\u0441\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435, \u043a\u043e\u0433\u0434\u0430 \u043c\u044b \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 (\u0432 URL-\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u0441 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u043e\u043d \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043c\u0435\u0436\u0434\u0443 \u00abhttps:\/\/docs.google.com\/spreadsheets\/d\/\u00bb \u0438 \u00ab\/edit#gid=0\u00bb).<\/p>\n\n\n\n<p>\u041c\u044b \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u043b\u0438 \u0435\u0433\u043e \u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 spreadsheetId \u0438 \u0434\u0430\u043b\u044c\u0448\u0435 \u0431\u0443\u0434\u0435\u043c \u0441 \u043d\u0438\u043c \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c.<\/p>\n\n\n\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0442\u0435\u043e\u0440\u0438\u0438.<\/p>\n\n\n\n<p>\u0412 \u043a\u0430\u0436\u0434\u043e\u043c \u0444\u0430\u0439\u043b\u0435 (spreadsheet) \u043d\u0430\u0445\u043e\u0434\u044f\u0442\u0441\u044f \u043b\u0438\u0441\u0442\u044b-\u0432\u043a\u043b\u0430\u0434\u043a\u0438 (sheet).<\/p>\n\n\n\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 sheet \u0438\u043c\u0435\u0435\u0442 \u0441\u0432\u043e\u0439 \u0447\u0438\u0441\u043b\u043e\u0432\u043e\u0439 \u043a\u043e\u0434 (sheetId). \u0423 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0433\u043e \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0435 \u043b\u0438\u0441\u0442\u0430 \u044d\u0442\u043e\u0442 Id \u0440\u0430\u0432\u0435\u043d 0. \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043b\u0438\u0441\u0442\u044b \u0438\u043c\u0435\u044e\u0442 \u0441\u0438\u043b\u044c\u043d\u043e \u043e\u0442\u043b\u0438\u0447\u043d\u044b\u0435 \u043e\u0442 \u043d\u0443\u043b\u044f Id (\u0442.\u0435. \u043e\u043d\u0438 \u043d\u0435 \u043d\u0443\u043c\u0435\u0440\u0443\u044e\u0442\u0441\u044f \u043f\u043e\u0434\u0440\u044f\u0434).<\/p>\n\n\n\n<p>\u0423\u0431\u0435\u0434\u0438\u043c\u0441\u044f \u0432 \u044d\u0442\u043e\u043c<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u0414\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u043b\u0438\u0441\u0442\u0430\nresults = service.spreadsheets().batchUpdate(\n    spreadsheetId = spreadsheetId,\n    body = \n{\n  \"requests\": [\n    {\n      \"addSheet\": {\n        \"properties\": {\n          \"title\": \"\u0415\u0449\u0435 \u043e\u0434\u0438\u043d \u043b\u0438\u0441\u0442\",\n          \"gridProperties\": {\n            \"rowCount\": 20,\n            \"columnCount\": 12\n          }\n        }\n      }\n    }\n  ]\n}).execute()\n\n\n# \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u043f\u0438\u0441\u043e\u043a \u043b\u0438\u0441\u0442\u043e\u0432, \u0438\u0445 Id \u0438 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\nspreadsheet = service.spreadsheets().get(spreadsheetId = spreadsheetId).execute()\nsheetList = spreadsheet.get('sheets')\nfor sheet in sheetList:\n    print(sheet['properties']['sheetId'], sheet['properties']['title'])\n    \nsheetId = sheetList[0]['properties']['sheetId']\n\nprint('\u041c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043b\u0438\u0441\u0442 \u0441 Id = ', sheetId)\n<\/pre>\n\n\n\n<p>\u041d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043d\u0435\u0447\u0442\u043e \u0432\u0440\u043e\u0434\u0435:<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>0 \u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d<br>415832263 \u0415\u0449\u0435 \u043e\u0434\u0438\u043d \u043b\u0438\u0441\u0442<br>\u041c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043b\u0438\u0441\u0442 \u0441 Id = 0<\/p>\n<\/blockquote>\n\n\n\n<p>\u0412 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435, \u043f\u0435\u0440\u0432\u044b\u0439 \u043b\u0438\u0441\u0442 \u0438\u043c\u0435\u0435\u0442 Id \u0440\u0430\u0432\u043d\u044b\u0439 \u043d\u0443\u043b\u044e, \u0430 \u0432\u0442\u043e\u0440\u043e\u0439 \u043f\u0440\u043e\u043d\u0443\u043c\u0435\u0440\u043e\u0432\u0430\u043d \u0438\u043d\u0430\u0447\u0435.<\/p>\n\n\n\n<p>\u0415\u0449\u0435 \u043e\u0434\u0438\u043d \u0432\u043e\u043f\u0440\u043e\u0441: \u043a\u0430\u043a \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u044b \u044f\u0447\u0435\u0435\u043a. \u0412\u0438\u0434\u0438\u043c\u043e, \u0442\u0430\u0431\u043b\u0438\u0446\u044b Google \u0440\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b\u0438 \u0440\u0430\u0437\u043d\u044b\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b, \u043f\u043e\u0434 \u0440\u0443\u043a\u043e\u0432\u043e\u0434\u0441\u0442\u0432\u043e\u043c \u0440\u0430\u0437\u043d\u044b\u0445 \u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440\u043e\u0432 \u0438 \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 \u0440\u0430\u0437\u043d\u044b\u0445 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u043e\u0440\u043e\u0432. \u041f\u043e\u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u044f\u0447\u0435\u0435\u043a \u0437\u0430\u0434\u0430\u044e\u0442\u0441\u044f \u0434\u0432\u0443\u043c\u044f \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c\u0438.<\/p>\n\n\n\n<p>\u0412\u0430\u0440\u0438\u0430\u043d\u0442 1: \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 \u0442\u0435\u043a\u0441\u0442\u0430 \u00ab\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d!B2:D5\u00bb, \u0442.\u0435. \u0438\u043c\u044f \u043b\u0438\u0441\u0442\u0430, \u043f\u043e\u0441\u043b\u0435 \u043d\u0435\u0433\u043e \u0432\u043e\u0441\u043a\u043b\u0438\u0446\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0437\u043d\u0430\u043a, \u043f\u043e\u0441\u043b\u0435 \u2014 \u043b\u0435\u0432\u0430\u044f \u0432\u0435\u0440\u0445\u043d\u044f\u044f \u044f\u0447\u0435\u0439\u043a\u0430 \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 \u00ab\u0431\u0443\u043a\u0432\u0430 (\u043a\u043e\u043b\u043e\u043d\u043a\u0430) + \u0446\u0438\u0444\u0440\u0430 (\u0441\u0442\u0440\u043e\u043a\u0430)\u00bb + \u043f\u0440\u0430\u0432\u0430\u044f \u043d\u0438\u0436\u043d\u044f\u044f \u044f\u0447\u0435\u0439\u043a\u0430 \u0432 \u0442\u0430\u043a\u043e\u043c \u0436\u0435 \u0444\u043e\u0440\u043c\u0430\u0442\u0435.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">{\"range\": \"\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d!B2:D5\"}<\/pre>\n\n\n\n<p>\u0412\u0430\u0440\u0438\u0430\u043d\u0442 2: \u0432 json-\u0444\u043e\u0440\u043c\u0430\u0442\u0435, \u0441 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435\u043c ID \u043b\u0438\u0441\u0442\u0430 \u0438 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u043b\u0435\u0432\u043e\u0439 \u0432\u0435\u0440\u0445\u043d\u0435\u0439 \u0438 \u043f\u0440\u0430\u0432\u043e\u0439 \u043d\u0438\u0436\u043d\u0435\u0439 \u044f\u0447\u0435\u0435\u043a \u0432 \u0447\u0438\u0441\u043b\u043e\u0432\u043e\u043c \u0432\u0438\u0434\u0435 (\u043d\u043e\u043c\u0435\u0440 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u043d\u043e\u043c\u0435\u0440 \u0441\u0442\u043e\u043b\u0431\u0446\u0430)<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">{\"range\":\n    {\n    \"sheetId\": sheetId, # ID \u043b\u0438\u0441\u0442\u0430\n    \"startRowIndex\": 1, # \u0421\u043e \u0441\u0442\u0440\u043e\u043a\u0438 \u043d\u043e\u043c\u0435\u0440 startRowIndex \n    \"endRowIndex\": 5,# \u043f\u043e endRowIndex - 1 (endRowIndex \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u0442!)\n    \"startColumnIndex\": 0, # \u0421\u043e \u0441\u0442\u043e\u043b\u0431\u0446\u0430 \u043d\u043e\u043c\u0435\u0440 startColumnIndex \n    \"endColumnIndex\": 1 # \u043f\u043e endColumnIndex - 1\n    }}<\/pre>\n\n\n\n<p>\u0420\u0430\u0437\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u0440\u0430\u0437\u043d\u044b\u0435 \u0444\u043e\u0440\u043c\u0430\u0442\u044b.<\/p>\n\n\n\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u044f\u0447\u0435\u0439\u043a\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438, \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u043c\u043a\u0443 \u0438 \u0432\u044b\u0434\u0435\u043b\u0438\u0442\u044c \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0438.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">results = service.spreadsheets().values().batchUpdate(spreadsheetId = spreadsheetId, body = {\n    \"valueInputOption\": \"USER_ENTERED\", # \u0414\u0430\u043d\u043d\u044b\u0435 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f, \u043a\u0430\u043a \u0432\u0432\u043e\u0434\u0438\u043c\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u043c (\u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0444\u043e\u0440\u043c\u0443\u043b)\n    \"data\": [\n        {\"range\": \"\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d!B2:D5\",\n         \"majorDimension\": \"ROWS\",     # \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0437\u0430\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0441\u0442\u0440\u043e\u043a\u0438, \u0437\u0430\u0442\u0435\u043c \u0441\u0442\u043e\u043b\u0431\u0446\u044b\n         \"values\": [\n                    [\"\u042f\u0447\u0435\u0439\u043a\u0430 B2\", \"\u042f\u0447\u0435\u0439\u043a\u0430 C2\", \"\u042f\u0447\u0435\u0439\u043a\u0430 D2\"], # \u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043f\u0435\u0440\u0432\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443\n                    ['25', \"=6*6\", \"=sin(3,14\/2)\"]  # \u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u0432\u0442\u043e\u0440\u0443\u044e \u0441\u0442\u0440\u043e\u043a\u0443\n                   ]}\n    ]\n}).execute()<\/pre>\n\n\n\n<p>\u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u044f\u0447\u0435\u0435\u043a \u0434\u0430\u043d\u043d\u044b\u043c\u0438. \u0422.\u043a. \u0443\u043a\u0430\u0437\u0430\u043d \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 USER_ENTERED, \u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u044d\u0442\u0438 \u0434\u0430\u043d\u043d\u044b\u0435 \u0442\u0430\u043a, \u043a\u0430\u043a \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u044f\u043b\u0430 \u0431\u044b \u0432\u0432\u043e\u0434 \u0440\u0443\u043a\u0430\u043c\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u2014 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u0443\u0435\u0442 \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432 \u0447\u0438\u0441\u043b\u0430, \u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f, \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0449\u0438\u0435\u0441\u044f \u0441\u043e \u0437\u043d\u0430\u043a\u0430 \u00ab\u0440\u0430\u0432\u043d\u043e\u00bb \u0432 \u0444\u043e\u0440\u043c\u0443\u043b\u044b.<\/p>\n\n\n\n<p>\u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u0432 \u0432\u0430\u0448\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u043e\u043d\u0430 \u0437\u0430\u043f\u043e\u043b\u043d\u0438\u043b\u0430\u0441\u044c \u0434\u0430\u043d\u043d\u044b\u043c\u0438<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/ob\/3h\/h_\/ob3hh_l6npzamjxabctqph8lrny.jpeg\"><\/p>\n\n\n\n<p>\u0417\u0430\u0434\u0430\u0434\u0438\u043c \u0448\u0438\u0440\u0438\u043d\u0443 \u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u0424\u0443\u043d\u043a\u0446\u0438\u044f batchUpdate \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043a\u043e\u043c\u0430\u043d\u0434 \u0441\u0440\u0430\u0437\u0443, \u0442\u0430\u043a \u0447\u0442\u043e \u043c\u044b \u043e\u0434\u043d\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c \u0448\u0438\u0440\u0438\u043d\u0443 \u0442\u0440\u0435\u0445 \u0433\u0440\u0443\u043f\u043f \u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u0412 \u043f\u0435\u0440\u0432\u043e\u0439 \u0438 \u0442\u0440\u0435\u0442\u044c\u0435\u0439 \u0433\u0440\u0443\u043f\u043f\u0435 \u043e\u0434\u043d\u0430 \u043a\u043e\u043b\u043e\u043d\u043a\u0430, \u0430 \u0432\u043e \u0432\u0442\u043e\u0440\u043e\u0439 \u2014 \u0434\u0432\u0435.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">results = service.spreadsheets().batchUpdate(spreadsheetId = spreadsheetId, body = {\n  \"requests\": [\n\n    # \u0417\u0430\u0434\u0430\u0442\u044c \u0448\u0438\u0440\u0438\u043d\u0443 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 A: 20 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439\n    {\n      \"updateDimensionProperties\": {\n        \"range\": {\n          \"sheetId\": sheetId,\n          \"dimension\": \"COLUMNS\",  # \u0417\u0430\u0434\u0430\u0435\u043c \u0448\u0438\u0440\u0438\u043d\u0443 \u043a\u043e\u043b\u043e\u043d\u043a\u0438\n          \"startIndex\": 0, # \u041d\u0443\u043c\u0435\u0440\u0430\u0446\u0438\u044f \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441 \u043d\u0443\u043b\u044f\n          \"endIndex\": 1 # \u0421\u043e \u0441\u0442\u043e\u043b\u0431\u0446\u0430 \u043d\u043e\u043c\u0435\u0440 startIndex \u043f\u043e endIndex - 1 (endIndex \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u0442!)\n        },\n        \"properties\": {\n          \"pixelSize\": 20 # \u0428\u0438\u0440\u0438\u043d\u0430 \u0432 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u0445\n        },\n        \"fields\": \"pixelSize\" # \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c, \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 pixelSize  \n      }\n    },\n\n    # \u0417\u0430\u0434\u0430\u0442\u044c \u0448\u0438\u0440\u0438\u043d\u0443 \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432 B \u0438 C: 150 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439\n    {\n      \"updateDimensionProperties\": {\n        \"range\": {\n          \"sheetId\": sheetId,\n          \"dimension\": \"COLUMNS\",\n          \"startIndex\": 1,\n          \"endIndex\": 3\n        },\n        \"properties\": {\n          \"pixelSize\": 150\n        },\n        \"fields\": \"pixelSize\"\n      }\n    },\n\n    # \u0417\u0430\u0434\u0430\u0442\u044c \u0448\u0438\u0440\u0438\u043d\u0443 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 D: 200 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439\n    {\n      \"updateDimensionProperties\": {\n        \"range\": {\n          \"sheetId\": sheetId,\n          \"dimension\": \"COLUMNS\",\n          \"startIndex\": 3,\n          \"endIndex\": 4\n        },\n        \"properties\": {\n          \"pixelSize\": 200\n        },\n        \"fields\": \"pixelSize\"\n      }\n    }\n  ]\n}).execute()<\/pre>\n\n\n\n<p>\u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u043d\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u0448\u0438\u0440\u0438\u043d\u044b \u043a\u043e\u043b\u043e\u043d\u043e\u043a \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c.<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/wu\/zv\/h4\/wuzvh4jz9uloyxlkhfnxqk7otke.jpeg\"><\/p>\n\n\n\n<p>\u041d\u0430\u0440\u0438\u0441\u0443\u0435\u043c \u0440\u0430\u043c\u043a\u0443 \u0432\u043e\u043a\u0440\u0443\u0433 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u0420\u0438\u0441\u0443\u0435\u043c \u0440\u0430\u043c\u043a\u0443\nresults = service.spreadsheets().batchUpdate(\n    spreadsheetId = spreadsheetId,\n    body = {\n        \"requests\": [\n            {'updateBorders': {'range': {'sheetId': sheetId,\n                             'startRowIndex': 1,\n                             'endRowIndex': 3,\n                             'startColumnIndex': 1,\n                             'endColumnIndex': 4},\n                   'bottom': {  \n                   # \u0417\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u044c \u0434\u043b\u044f \u0432\u0435\u0440\u0445\u043d\u0435\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b\n                              'style': 'SOLID', # \u0421\u043f\u043b\u043e\u0448\u043d\u0430\u044f \u043b\u0438\u043d\u0438\u044f\n                              'width': 1,       # \u0428\u0438\u0440\u0438\u043d\u043e\u0439 1 \u043f\u0438\u043a\u0441\u0435\u043b\u044c\n                              'color': {'red': 0, 'green': 0, 'blue': 0, 'alpha': 1}}, # \u0427\u0435\u0440\u043d\u044b\u0439 \u0446\u0432\u0435\u0442\n                   'top': { \n                   # \u0417\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u044c \u0434\u043b\u044f \u043d\u0438\u0436\u043d\u0435\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b\n                              'style': 'SOLID',\n                              'width': 1,\n                              'color': {'red': 0, 'green': 0, 'blue': 0, 'alpha': 1}},\n                   'left': { # \u0417\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u044c \u0434\u043b\u044f \u043b\u0435\u0432\u043e\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b\n                              'style': 'SOLID',\n                              'width': 1,\n                              'color': {'red': 0, 'green': 0, 'blue': 0, 'alpha': 1}},\n                   'right': { \n                   # \u0417\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u044c \u0434\u043b\u044f \u043f\u0440\u0430\u0432\u043e\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b\n                              'style': 'SOLID',\n                              'width': 1,\n                              'color': {'red': 0, 'green': 0, 'blue': 0, 'alpha': 1}},\n                   'innerHorizontal': { \n                   # \u0417\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u044c \u0434\u043b\u044f \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u043b\u0438\u043d\u0438\u0439\n                              'style': 'SOLID',\n                              'width': 1,\n                              'color': {'red': 0, 'green': 0, 'blue': 0, 'alpha': 1}},\n                   'innerVertical': { \n                   # \u0417\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u044c \u0434\u043b\u044f \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0445 \u043b\u0438\u043d\u0438\u0439\n                              'style': 'SOLID',\n                              'width': 1,\n                              'color': {'red': 0, 'green': 0, 'blue': 0, 'alpha': 1}}\n                              \n                              }}\n        ]\n    }).execute()\n<\/pre>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/7v\/8l\/db\/7v8ldbkjnukd2j6lukhezmaupje.jpeg\"><\/p>\n\n\n\n<p>\u041e\u0431\u044a\u0435\u0434\u0438\u043d\u0438\u043c \u044f\u0447\u0435\u0439\u043a\u0438 \u043d\u0430\u0434 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u0438 \u0432\u043f\u0438\u0448\u0435\u043c \u0432 \u043d\u0438\u0445 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u0435\u043c \u044f\u0447\u0435\u0439\u043a\u0438 A2:D1\nresults = service.spreadsheets().batchUpdate(\n    spreadsheetId = spreadsheetId,\n    body = {\n        \"requests\": [\n            {'mergeCells': {'range': {'sheetId': sheetId,\n                          'startRowIndex': 0,\n                          'endRowIndex': 1,\n                          'startColumnIndex': 1,\n                          'endColumnIndex': 4},\n                'mergeType': 'MERGE_ALL'}}\n        ]\n    }).execute()\n# \u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a \u0442\u0430\u0431\u043b\u0438\u0446\u044b\nresults = service.spreadsheets().values().batchUpdate(spreadsheetId = spreadsheetId, body = {\n    \"valueInputOption\": \"USER_ENTERED\",\n# \u0414\u0430\u043d\u043d\u044b\u0435 \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f, \u043a\u0430\u043a \u0432\u0432\u043e\u0434\u0438\u043c\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u043c (\u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0444\u043e\u0440\u043c\u0443\u043b)\n    \"data\": [\n        {\"range\": \"\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d!B1\",\n         \"majorDimension\": \"ROWS\", # \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0437\u0430\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0441\u0442\u0440\u043e\u043a\u0438, \u0437\u0430\u0442\u0435\u043c \u0441\u0442\u043e\u043b\u0431\u0446\u044b\n         \"values\": [[\"\u0417\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a \u0442\u0430\u0431\u043b\u0438\u0446\u044b\" ] \n                   ]}\n    ]\n}).execute()\n<\/pre>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/ba\/pi\/tq\/bapitq07wcnkdodrbmodxssvvl8.jpeg\"><\/p>\n\n\n\n<p>\u0423\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c \u0444\u043e\u0440\u043c\u0430\u0442 \u0443 \u044f\u0447\u0435\u0435\u043a \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u0423\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0444\u043e\u0440\u043c\u0430\u0442\u0430 \u044f\u0447\u0435\u0435\u043a\nresults = service.spreadsheets().batchUpdate(\n    spreadsheetId = spreadsheetId,\n    body = \n{\n  \"requests\": \n  [\n    {\n      \"repeatCell\": \n      {\n        \"cell\": \n        {\n          \"userEnteredFormat\": \n          {\n            \"horizontalAlignment\": 'CENTER',\n            \"backgroundColor\": {\n                \"red\": 0.8,\n                \"green\": 0.8,\n                \"blue\": 0.8,\n                \"alpha\": 1\n            },\n            \"textFormat\":\n             {\n               \"bold\": True,\n               \"fontSize\": 14\n             }\n          }\n        },\n        \"range\": \n        {\n          \"sheetId\": sheetId,\n          \"startRowIndex\": 1,\n          \"endRowIndex\": 2,\n          \"startColumnIndex\": 1,\n          \"endColumnIndex\": 4\n        },\n        \"fields\": \"userEnteredFormat\"\n      }\n    }\n  ]\n}).execute()\n<\/pre>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/an\/mx\/ix\/anmxixf0r8g3tgobvulohsg3w5i.jpeg\"><\/p>\n\n\n\n<p>\u0415\u0441\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0443\u0437\u043d\u0430\u0442\u044c, \u043a\u0430\u043a\u0443\u044e \u0448\u0438\u0440\u0438\u043d\u0443 \u0438\u043b\u0438 \u0446\u0432\u0435\u0442 \u043d\u0443\u0436\u043d\u043e \u0437\u0430\u0434\u0430\u0442\u044c \u044f\u0447\u0435\u0439\u043a\u0435. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0432\u0440\u0443\u0447\u043d\u0443\u044e \u043e\u0442\u0444\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0434\u043d\u0443 \u0438\u0437 \u044f\u0447\u0435\u0435\u043a \u0438 \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0435\u0435 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">ranges = [\"\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d!C2:C2\"] # \n          \nresults = service.spreadsheets().get(spreadsheetId = spreadsheetId, \n                                     ranges = ranges, includeGridData = True).execute()\nprint('\u041e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435')\nprint(results['properties'])\nprint('\\n\u0417\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0438 \u0440\u0430\u0441\u043a\u0440\u0430\u0441\u043a\u0430')\nprint(results['sheets'][0]['data'][0]['rowData'] )\nprint('\\n\u0412\u044b\u0441\u043e\u0442\u0430 \u044f\u0447\u0435\u0439\u043a\u0438')\nprint(results['sheets'][0]['data'][0]['rowMetadata'])\nprint('\\n\u0428\u0438\u0440\u0438\u043d\u0430 \u044f\u0447\u0435\u0439\u043a\u0438')\nprint(results['sheets'][0]['data'][0]['columnMetadata'])\n<\/pre>\n\n\n\n<p>\u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0432 \u043e\u0442\u0432\u0435\u0442<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>\u041e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435<br>{&#8216;title&#8217;: &#8216;\u041f\u0435\u0440\u0432\u044b\u0439 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442&#8217;, &#8216;locale&#8217;: &#8216;ru_RU&#8217;, &#8216;autoRecalc&#8217;: &#8216;ON_CHANGE&#8217;, &#8216;timeZone&#8217;: &#8216;Etc\/GMT&#8217;, &#8216;defaultFormat&#8217;: {&#8216;backgroundColor&#8217;: {&#8216;red&#8217;: 1, &#8216;green&#8217;: 1, &#8216;blue&#8217;: 1}, &#8216;padding&#8217;: {&#8216;top&#8217;: 2, &#8216;right&#8217;: 3, &#8216;bottom&#8217;: 2, &#8216;left&#8217;: 3}, &#8216;verticalAlignment&#8217;: &#8216;BOTTOM&#8217;, &#8216;wrapStrategy&#8217;: &#8216;OVERFLOW_CELL&#8217;, &#8216;textFormat&#8217;: {&#8216;foregroundColor&#8217;: {}, &#8216;fontFamily&#8217;: &#8216;arial,sans,sans-serif&#8217;, &#8216;fontSize&#8217;: 10, &#8216;bold&#8217;: False, &#8216;italic&#8217;: False, &#8216;strikethrough&#8217;: False, &#8216;underline&#8217;: False}}}<\/p>\n\n\n\n<p>\u0417\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0438 \u0440\u0430\u0441\u043a\u0440\u0430\u0441\u043a\u0430<br>[{&#8216;values&#8217;: [{&#8216;userEnteredValue&#8217;: {&#8216;stringValue&#8217;: &#8216;\u042f\u0447\u0435\u0439\u043a\u0430 C2&#8217;}, &#8216;effectiveValue&#8217;: {&#8216;stringValue&#8217;: &#8216;\u042f\u0447\u0435\u0439\u043a\u0430 C2&#8217;}, &#8216;formattedValue&#8217;: &#8216;\u042f\u0447\u0435\u0439\u043a\u0430 C2&#8217;, &#8216;userEnteredFormat&#8217;: {&#8216;backgroundColor&#8217;: {&#8216;red&#8217;: 1, &#8216;green&#8217;: 0.6}, &#8216;horizontalAlignment&#8217;: &#8216;CENTER&#8217;, &#8216;textFormat&#8217;: {&#8216;fontSize&#8217;: 14, &#8216;bold&#8217;: True, &#8216;italic&#8217;: True}}, &#8216;effectiveFormat&#8217;: {&#8216;backgroundColor&#8217;: {&#8216;red&#8217;: 1, &#8216;green&#8217;: 0.6}, &#8216;padding&#8217;: {&#8216;top&#8217;: 2, &#8216;right&#8217;: 3, &#8216;bottom&#8217;: 2, &#8216;left&#8217;: 3}, &#8216;horizontalAlignment&#8217;: &#8216;CENTER&#8217;, &#8216;verticalAlignment&#8217;: &#8216;BOTTOM&#8217;, &#8216;wrapStrategy&#8217;: &#8216;OVERFLOW_CELL&#8217;, &#8216;textFormat&#8217;: {&#8216;foregroundColor&#8217;: {}, &#8216;fontFamily&#8217;: &#8216;Arial&#8217;, &#8216;fontSize&#8217;: 14, &#8216;bold&#8217;: True, &#8216;italic&#8217;: True, &#8216;strikethrough&#8217;: False, &#8216;underline&#8217;: False}, &#8216;hyperlinkDisplayType&#8217;: &#8216;PLAIN_TEXT&#8217;}}]}]<\/p>\n\n\n\n<p>\u0412\u044b\u0441\u043e\u0442\u0430 \u044f\u0447\u0435\u0439\u043a\u0438<br>[{&#8216;pixelSize&#8217;: 21}]<\/p>\n\n\n\n<p>\u0428\u0438\u0440\u0438\u043d\u0430 \u044f\u0447\u0435\u0439\u043a\u0438<br>[{&#8216;pixelSize&#8217;: 150}]<\/p>\n<\/blockquote>\n\n\n\n<p>\u042d\u0442\u043e\u0442 \u043a\u043e\u0434 \u0432\u044b\u0432\u0435\u0434\u0435\u0442 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u044f\u0447\u0435\u0439\u043a\u0438 C2. \u041c\u043e\u0436\u043d\u043e \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u0448\u0440\u0438\u0444\u0442 \u0438 \u0446\u0432\u0435\u0442 \u0437\u0430\u043b\u0438\u0432\u043a\u0438 \u0432\u0440\u0443\u0447\u043d\u0443\u044e (\u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0435), \u0432 \u043f\u043e\u0442\u043e\u043c \u0443\u0432\u0438\u0434\u0435\u0442\u044c, \u043a\u0430\u043a \u043e\u043d\u0438 \u043e\u0442\u0440\u0430\u0436\u0430\u044e\u0442\u0441\u044f \u0432 json.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u0427\u0442\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438\u0437 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/h2>\n\n\n\n<p>\u0427\u0442\u043e\u0431\u044b \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0447\u0442\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u0440\u043e\u044f\u0432\u0438\u043b\u0438\u0441\u044c \u0432 \u043f\u043e\u043b\u043d\u043e\u0439 \u043c\u0435\u0440\u0435, \u044f \u0432\u0440\u0443\u0447\u043d\u0443\u044e \u0437\u0430\u043f\u043e\u043b\u043d\u0438\u043b \u044f\u0447\u0435\u0439\u043a\u0438 B4, C7 \u0438 D5 \u043a\u0430\u043a \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e \u043d\u0430 \u0440\u0438\u0441\u0443\u043d\u043a\u0435.<\/p>\n\n\n\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/ms\/yc\/ph\/msycphwvaxu8x49rvc2vq6zwdfo.jpeg\"><\/p>\n\n\n\n<p>\u041a\u043e\u0434 \u0434\u043b\u044f \u0447\u0442\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"python\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">ranges = [\"\u041b\u0438\u0441\u0442 \u043d\u043e\u043c\u0435\u0440 \u043e\u0434\u0438\u043d!A2:F8\"] # \n          \nresults = service.spreadsheets().values().batchGet(spreadsheetId = spreadsheetId, \n                                     ranges = ranges, \n                                     valueRenderOption = 'FORMATTED_VALUE',  \n                                     dateTimeRenderOption = 'FORMATTED_STRING').execute() \nsheet_values = results['valueRanges'][0]['values']\nprint(sheet_values)<\/pre>\n\n\n\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>[[&#187;, &#8216;\u042f\u0447\u0435\u0439\u043a\u0430 B2&#8217;, &#8216;\u042f\u0447\u0435\u0439\u043a\u0430 C2&#8217;, &#8216;\u042f\u0447\u0435\u0439\u043a\u0430 D2&#8242;], [&#187;, &#8217;25&#8217;, &#8217;36&#8217;, &#8216;0,9999996829&#8217;]]<\/p>\n<\/blockquote>\n\n\n\n<p>\u041d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0444\u0443\u043d\u043a\u0446\u0438\u0438:&nbsp;<em>valueRenderOption<\/em>&nbsp;\u2014 \u0444\u043e\u0440\u043c\u0430\u0442 \u0447\u0442\u0435\u043d\u0438\u044f \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>FORMATTED_VALUE<\/strong>\u00a0\u2014 \u0447\u0442\u0435\u043d\u0438\u0435 \u0441 \u0443\u0447\u0435\u0442\u043e\u043c \u0444\u043e\u0440\u043c\u0430\u0442\u0430 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f. \u0422.\u0435. \u0447\u0442\u043e \u0431\u044b\u043b\u043e \u0432\u0438\u0434\u043d\u043e \u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0435, \u0442\u043e \u0438 \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432 \u044f\u0447\u0435\u0439\u043a\u0435 D3 \u0447\u0438\u0441\u043b\u043e 0,9999999, \u043d\u043e \u0432\u044b\u0431\u0440\u0430\u043d \u0444\u043e\u0440\u043c\u0430\u0442 \u00ab\u0434\u0432\u0430 \u0437\u043d\u0430\u043a\u0430 \u043f\u043e\u0441\u043b\u0435 \u0437\u0430\u043f\u044f\u0442\u043e\u0439\u00bb, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u00ab1,00\u00bb, \u0438\u043c\u0435\u043d\u043d\u043e \u0432 \u0442\u0430\u043a\u043e\u043c \u0444\u043e\u0440\u043c\u0430\u0442\u0435 \u043e\u043d\u043e \u0438 \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f.<\/li>\n\n\n\n<li><strong>UNFORMATTED_VALUE<\/strong>\u00a0\u2014 \u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u044f\u0447\u0435\u0439\u043a\u0438, \u0431\u0435\u0437 \u0443\u0447\u0435\u0442\u0430 \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a \u0444\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 (\u0442.\u0435. \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u043b\u043e\u0441\u044c \u0431\u044b 0,9999999)<\/li>\n\n\n\n<li><strong>FORMULA<\/strong>\u00a0\u2014 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u0444\u043e\u0440\u043c\u0443\u043b\u0430 (\u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u00ab=sin(3,14\/2)\u00bb. \u0415\u0441\u043b\u0438 \u0432 \u044f\u0447\u0435\u0439\u043a\u0435 \u0432\u0432\u0435\u0434\u0435\u043d\u043e \u0447\u0438\u0441\u043b\u043e, \u0442\u043e \u0432 \u044d\u0442\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435 \u043e\u043d\u043e \u0438 \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f.<\/li>\n<\/ul>\n\n\n\n<p>\u042d\u0442\u043e\u0442 \u043a\u043e\u0434 \u0447\u0438\u0442\u0430\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0435 \u0438 \u043f\u043e\u0441\u0442\u0440\u043e\u0447\u043d\u043e \u0432\u044b\u0432\u043e\u0434\u0438\u0442 \u0438\u0445 \u043d\u0430 \u044d\u043a\u0440\u0430\u043d. \u0427\u0438\u0442\u0430\u0435\u043c\u044b\u0439 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d A2:F8.<br>\u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u0415\u0441\u043b\u0438 \u043d\u0438 \u043e\u0434\u043d\u0430 \u044f\u0447\u0435\u0439\u043a\u0430 \u0432 \u0447\u0438\u0442\u0430\u0435\u043c\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u043d\u0435 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0430 \u2014 \u0434\u0430\u043d\u043d\u044b\u0435 \u043f\u043e \u0441\u0442\u0440\u043e\u043a\u0435 \u043d\u0435 \u0432\u044b\u0432\u043e\u0434\u044f\u0442\u0441\u044f.<\/li>\n\n\n\n<li>\u0414\u0430\u043d\u043d\u044b\u0435 \u043f\u043e\u0441\u043b\u0435 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u043d\u043e\u0439 \u044f\u0447\u0435\u0439\u043a\u0438 \u043d\u0435 \u0432\u044b\u0432\u043e\u0434\u044f\u0442\u0441\u044f.<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>URL \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u041d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 Google Sheets (Google \u0422\u0430\u0431\u043b\u0438\u0446\u044b) \u043d\u0430 Python. \u041e\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0434\u043e \u0447\u0442\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445 Python&nbsp;*Google API&nbsp;*\u0418\u0437 \u043f\u0435\u0441\u043e\u0447\u043d\u0438\u0446\u044b\u0414\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0434\u043e\u043b\u0433\u043e \u044f \u043e\u0431\u0445\u043e\u0434\u0438\u043b\u0441\u044f \u0432\u044b\u0433\u0440\u0443\u0437\u043a\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 Excel, \u043d\u043e \u043c\u043e\u0434\u0430 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f, \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0445\u043e\u0442\u044f\u0442 \u0432 \u043e\u0431\u043b\u0430\u043a\u0430. \u041d\u0430\u0447\u0430\u0432 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u044c \u0440\u044f\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 Python, \u0440\u0435\u0448\u0438\u043b, \u0447\u0442\u043e \u0441\u0430\u043c\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0441\u043c\u0435\u043d\u0438\u0442\u044c (\u0438\u043b\u0438 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u044c) Excel \u0447\u0435\u043c-\u0442\u043e \u0431\u043e\u043b\u0435\u0435 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u043c. \u041a\u043e\u0433\u0434\u0430 \u044f \u0432\u043f\u0435\u0440\u0432\u044b\u0435 \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0441\u044f \u0441&hellip;&nbsp;<a href=\"http:\/\/1.cbm.ua\/?p=2151\" rel=\"bookmark\">\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 &raquo;<span class=\"screen-reader-text\">\u2764\ufe0f ___ \u041d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 Google Sheets (Google \u0422\u0430\u0431\u043b\u0438\u0446\u044b) \u043d\u0430 Python. \u041e\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0434\u043e \u0447\u0442\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445. (spreadsheets \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439; docs.google.com)<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"neve_meta_sidebar":"","neve_meta_container":"","neve_meta_enable_content_width":"","neve_meta_content_width":0,"neve_meta_title_alignment":"","neve_meta_author_avatar":"","neve_post_elements_order":"","neve_meta_disable_header":"","neve_meta_disable_footer":"","neve_meta_disable_title":"","footnotes":""},"categories":[110],"tags":[],"class_list":["post-2151","post","type-post","status-publish","format-standard","hentry","category-110"],"_links":{"self":[{"href":"http:\/\/1.cbm.ua\/index.php?rest_route=\/wp\/v2\/posts\/2151","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/1.cbm.ua\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/1.cbm.ua\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/1.cbm.ua\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/1.cbm.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2151"}],"version-history":[{"count":4,"href":"http:\/\/1.cbm.ua\/index.php?rest_route=\/wp\/v2\/posts\/2151\/revisions"}],"predecessor-version":[{"id":6374,"href":"http:\/\/1.cbm.ua\/index.php?rest_route=\/wp\/v2\/posts\/2151\/revisions\/6374"}],"wp:attachment":[{"href":"http:\/\/1.cbm.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2151"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/1.cbm.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2151"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/1.cbm.ua\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2151"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}