{"id":333345,"date":"2022-05-19T09:00:31","date_gmt":"2022-05-19T09:00:31","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=333345"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=333345","title":{"rendered":"<span>\u0423\u0441\u043a\u043e\u0440\u044f\u0435\u043c dplyr: \u0431\u0435\u043a\u0435\u043d\u0434\u044b dtplyr, multidplyr \u0438 dbplyr (\u0432\u0438\u0434\u0435\u043e \u0443\u0440\u043e\u043a + \u043a\u043e\u043d\u0441\u043f\u0435\u043a\u0442)<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><code>dplyr<\/code> \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 \u0434\u043b\u044f \u044f\u0437\u044b\u043a\u0430 R, \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u043c \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0443\u0434\u043e\u0431\u043e\u0447\u0438\u0442\u0430\u0435\u043c\u044b\u0439 \u0438 \u043f\u043e\u043d\u044f\u0442\u043d\u044b\u0439 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441. \u0418\u0437 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u043e\u0432 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u0430\u043a\u0435\u0442\u0430 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u043f\u0440\u0438 \u0440\u0430\u0431\u043e\u0442\u0435 \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430 \u043e\u043d \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0443\u0441\u0442\u0443\u043f\u0430\u0435\u0442 \u0432 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 <code>data.table<\/code>.<\/p>\n<p>\u0412 \u044d\u0442\u043e\u043c \u0432\u0438\u0434\u0435\u043e \u0443\u0440\u043e\u043a\u0435 \u043c\u044b \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c\u0441\u044f \u0441 \u0442\u0435\u043c, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043d\u0430 <code>dplyr<\/code>, \u0437\u0430 \u0441\u0447\u0451\u0442 \u0431\u0435\u043a\u0435\u043d\u0434\u043e\u0432 <code>dtplyr<\/code> \u0438 <code>multidplyr<\/code>, \u0430 \u0442\u0430\u043a \u0436\u0435 \u0443\u0437\u043d\u0430\u0435\u043c \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u0438 \u0437\u0430\u0447\u0435\u043c \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0431\u0435\u043a\u0435\u043d\u0434 <code>dbplyr<\/code>, \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044b\u0439 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0431\u0430\u0437\u0430\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/177\/463\/3c9\/1774633c92f704c4a7a3468fc95f2dc0.png\" width=\"1280\" height=\"720\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/177\/463\/3c9\/1774633c92f704c4a7a3468fc95f2dc0.png\"\/><figcaption><\/figcaption><\/figure>\n<h2>\u0421\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435<\/h2>\n<p><em>\u0415\u0441\u043b\u0438 \u0432\u044b \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u0435\u0442\u0435\u0441\u044c \u0430\u043d\u0430\u043b\u0438\u0437\u043e\u043c \u0434\u0430\u043d\u043d\u044b\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u0432\u0430\u043c \u0431\u0443\u0434\u0443\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u044b \u043c\u043e\u0438\u00a0<\/em><a href=\"https:\/\/t.me\/R4marketing\" rel=\"noopener noreferrer nofollow\"><em>telegram<\/em><\/a><em>\u00a0\u0438\u00a0<\/em><a href=\"https:\/\/www.youtube.com\/R4marketing\/?sub_confirmation=1\" rel=\"noopener noreferrer nofollow\"><em>youtube<\/em><\/a><em>\u00a0\u043a\u0430\u043d\u0430\u043b\u044b. \u0411\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u044b \u044f\u0437\u044b\u043a\u0443 R.<\/em>  <\/p>\n<ol>\n<li>\n<p><a href=\"#video\" rel=\"noopener noreferrer nofollow\">\u0412\u0438\u0434\u0435\u043e<\/a><\/p>\n<ol>\n<li>\n<p><a href=\"#time_code\" rel=\"noopener noreferrer nofollow\">\u0422\u0430\u0439\u043c \u043a\u043e\u0434\u044b<\/a><\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#presentation\" rel=\"noopener noreferrer nofollow\">\u041f\u0440\u0435\u0437\u0435\u043d\u0442\u0430\u0446\u0438\u044f<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#conspekt\" rel=\"noopener noreferrer nofollow\">\u041a\u0440\u0430\u0442\u043a\u0438\u0439 \u043a\u043e\u043d\u0441\u043f\u0435\u043a\u0442<\/a><\/p>\n<ol>\n<li>\n<p><a href=\"#dtplyr\" rel=\"noopener noreferrer nofollow\">dtplyr<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#dbplyr\" rel=\"noopener noreferrer nofollow\">dbplyr<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#multidplyr\" rel=\"noopener noreferrer nofollow\">multidplyr<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#choice\" rel=\"noopener noreferrer nofollow\">\u041a\u0430\u043a\u043e\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u0432\u044b\u0431\u0440\u0430\u0442\u044c<\/a><\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#conclusion\" rel=\"noopener noreferrer nofollow\">\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/a><\/p>\n<\/li>\n<\/ol>\n<p><a class=\"anchor\" name=\"video\" id=\"video\"><\/a><\/p>\n<h2>\u0412\u0438\u0434\u0435\u043e<\/h2>\n<div class=\"tm-iframe_temp\" data-src=\"https:\/\/embedd.srv.habr.com\/iframe\/6285f8b007a8cd4fd1f4b5fa\" data-style=\"\" id=\"6285f8b007a8cd4fd1f4b5fa\" width=\"\"><\/div>\n<p><a class=\"anchor\" name=\"time_code\" id=\"time_code\"><\/a><\/p>\n<h3>\u0422\u0430\u0439\u043c \u043a\u043e\u0434\u044b:<\/h3>\n<ul>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=0s\" rel=\"noopener noreferrer nofollow\">00:00<\/a> \u0412\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=59s\" rel=\"noopener noreferrer nofollow\">00:59<\/a> \u041a\u0430\u043a\u0438\u0435 \u0431\u0435\u043a\u0435\u043d\u0434\u044b \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=108s\" rel=\"noopener noreferrer nofollow\">01:48<\/a> \u0426\u0435\u043b\u044c <code>dtplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=150s\" rel=\"noopener noreferrer nofollow\">02:30<\/a> \u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <code>dtplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=213s\" rel=\"noopener noreferrer nofollow\">03:33<\/a> \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <code>dtplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=338s\" rel=\"noopener noreferrer nofollow\">05:38<\/a> \u041a\u0430\u043a \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 <code>dplyr<\/code> \u0432 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <code>data.table<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=471s\" rel=\"noopener noreferrer nofollow\">07:51<\/a> \u0424\u0443\u043d\u043a\u0446\u0438\u044f <code>show_query()<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=687s\" rel=\"noopener noreferrer nofollow\">11:27<\/a> \u041f\u043e\u0447\u0435\u043c\u0443 dtplyr \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435 \u0447\u0435\u043c <code>data,table<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=804s\" rel=\"noopener noreferrer nofollow\">13:24<\/a> \u0426\u0435\u043b\u044c <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=820s\" rel=\"noopener noreferrer nofollow\">13:40<\/a> \u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=877s\" rel=\"noopener noreferrer nofollow\">14:37<\/a> \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1014s\" rel=\"noopener noreferrer nofollow\">16:54<\/a> \u041f\u0435\u0440\u0435\u0432\u043e\u0434 <code>dplyr<\/code> \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 \u0432 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u044b <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1073s\" rel=\"noopener noreferrer nofollow\">17:53<\/a> \u041a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432 <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1105s\" rel=\"noopener noreferrer nofollow\">18:25<\/a> \u041f\u0435\u0440\u0435\u0432\u043e\u0434 \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 R \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0438 \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u043e\u0432 \u0432 SQL \u0437\u0430\u043f\u0440\u043e\u0441 <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1188s\" rel=\"noopener noreferrer nofollow\">19:48<\/a> \u041f\u0440\u043e\u0431\u0440\u043e\u0441 SQL \u043a\u043e\u043c\u0430\u043d\u0434 \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u044b <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1215s\" rel=\"noopener noreferrer nofollow\">20:15<\/a> \u041a\u0430\u043a \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0432\u043d\u0443\u0442\u0440\u0438 <code>dplyr<\/code> \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 \u0432 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0444\u0443\u043d\u043a\u0446\u0438\u044f <code>translate_sql()<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1286s\" rel=\"noopener noreferrer nofollow\">21:26<\/a> \u0412\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0432 <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1337s\" rel=\"noopener noreferrer nofollow\">22:17<\/a> \u0412\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1370s\" rel=\"noopener noreferrer nofollow\">22:50<\/a> \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1704s\" rel=\"noopener noreferrer nofollow\">28:24<\/a> \u041a\u0430\u043a\u043e\u0439 \u043f\u0430\u043a\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>dtplyr<\/code> \u0438\u043b\u0438 <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1767s\" rel=\"noopener noreferrer nofollow\">29:27<\/a> \u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435  <\/p>\n<\/li>\n<\/ul>\n<p><a class=\"anchor\" name=\"presentation\" id=\"presentation\"><\/a><\/p>\n<h2>\u041f\u0440\u0435\u0437\u0435\u043d\u0442\u0430\u0446\u0438\u044f<\/h2>\n<div class=\"tm-iframe_temp\" data-src=\"https:\/\/embedd.srv.habr.com\/iframe\/627f66cc15db00b4622648ae\" data-style=\"\" id=\"627f66cc15db00b4622648ae\" width=\"\"><\/div>\n<p><a class=\"anchor\" name=\"conspekt\" id=\"conspekt\"><\/a><\/p>\n<h2>\u041a\u0440\u0430\u0442\u043a\u0438\u0439 \u043a\u043e\u043d\u0441\u043f\u0435\u043a\u0442<\/h2>\n<p><a class=\"anchor\" name=\"dtplyr\" id=\"dtplyr\"><\/a><\/p>\n<h3>dtplyr<\/h3>\n<p>\u0426\u0435\u043b\u044c <code>dtplyr<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u0432\u0430\u043c \u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434 dplyr, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u0442\u0440\u0430\u043d\u0441\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 \u044d\u043a\u0432\u0438\u0432\u0430\u043b\u0435\u043d\u0442\u043d\u044b\u0439, \u043d\u043e \u0437\u0430\u0447\u0430\u0441\u0442\u0443\u044e \u0431\u043e\u043b\u0435\u0435 \u0431\u044b\u0441\u0442\u0440\u044b\u0439, \u043a\u043e\u0434 <code>data.table<\/code>.<\/p>\n<h4>\u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 dtplyr:<\/h4>\n<ul>\n<li>\n<p><code>lazy_dt()<\/code> &#8212; \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 <code>dtplyr<\/code> \u0434\u043b\u044f \u043b\u0435\u043d\u0438\u0432\u044b\u0445 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 (\u043f\u0435\u0440\u0432\u043e\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435);<\/p>\n<\/li>\n<li>\n<p><code>dplyr<\/code> &#8212; \u0434\u0430\u043b\u0435\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>lazy_dt()<\/code> \u043e\u0431\u044a\u0435\u043a\u0442 \u0441 \u0433\u043b\u0430\u0433\u043e\u043b\u0430\u043c\u0438 <code>dplyr<\/code>, \u0434\u043b\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0438\u043a\u0430\u043a\u0438\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043d\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u044f\u0442\u0441\u044f, \u0430 \u043b\u0438\u0448\u044c \u043e\u0446\u0435\u043d\u0438\u0432\u0430\u044e\u0442\u0441\u044f;<\/p>\n<\/li>\n<li>\n<p><code>show_query()<\/code> &#8212; \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432 \u043a\u0430\u043a\u043e\u0435 <code>data.table<\/code> \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u044b \u0432\u0430\u0448\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f;<\/p>\n<\/li>\n<li>\n<p><code>as.data.table()<\/code> \/ <code>as.data.frame()<\/code> \/ <code>as_tibble()<\/code> &#8212; \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f, \u0438 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043a \u0442\u043e\u043c\u0443 \u0442\u0438\u043f\u0443, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0432\u044b\u0431\u0440\u0430\u043d\u043d\u043e\u0439 \u0432\u0430\u043c\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0438.<\/p>\n<\/li>\n<\/ul>\n<h4>\u041f\u0440\u0438\u043c\u0435\u0440\u044b \u043a\u043e\u0434\u0430 dtplyr<\/h4>\n<details class=\"spoiler\">\n<summary>\u041f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u0438\u0439 \u0441 dtplyr<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"r\"># dtplyr library(data.table) library(dtplyr) library(dplyr, warn.conflicts = FALSE)  # dtplyr \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043b\u0435\u043d\u0438\u0432\u044b\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f mtcars2 &lt;- lazy_dt(mtcars)  # \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 mtcars2 %>%    filter(wt &lt; 5) %>%    mutate(l100k = 235.21 \/ mpg) %>% # liters \/ 100 km   group_by(cyl) %>%    summarise(l100k = mean(l100k))  # \u043d\u043e \u0434\u043b\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c #  as.data.table(), as.data.frame() \u0438\u043b\u0438 as_tibble() mtcars2 %>%    filter(wt &lt; 5) %>%    mutate(l100k = 235.21 \/ mpg) %>% # liters \/ 100 km   group_by(cyl) %>%    summarise(l100k = mean(l100k)) %>%    as_tibble()  # \u0431\u043e\u043b\u0435\u0435 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u043a\u043e\u0434\u0430 df &lt;- data.frame(a = 1:5, b = 1:5, c = 1:5, d = 1:5) dt &lt;- lazy_dt(df)  # \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u0440\u0435\u0434\u0432\u0430\u0440\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e \u043e\u0446\u0435\u043d\u043a\u0443 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0430 dt # \u0435\u0441\u043b\u0438 \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u0435 \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 data.table # \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d \u043a\u043e\u0434 dplyr \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c show_query() dt %>% show_query()  # \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0433\u043b\u0430\u0433\u043e\u043b\u044b  ## filter() \/ arrange() - i dt %>% arrange(a, b, c) %>% show_query() dt %>% filter(b == c) %>% show_query() dt %>% filter(b == c, c == d) %>% show_query()  ## select(), summarise(),transmute() - j dt %>% select(a:b) %>% show_query() dt %>% summarise(a = mean(a)) %>% show_query() dt %>% transmute(a2 = a * 2) %>% show_query()  ## mutate - j + := dt %>% mutate(a2 = a * 2, b2 = b * 2) %>% show_query()  # \u0414\u0440\u0443\u0433\u0438\u0435 \u0433\u043b\u0430\u0433\u043e\u043b\u044b dplyr ## rename - setnames dt %>% rename(x = a, y = b) %>% show_query() ## distinct - unique dt %>% distinct() %>% show_query() dt %>% distinct(a, b) %>% show_query() dt %>% distinct(a, b, .keep_all = TRUE) %>% show_query()  # \u041e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f dt2 &lt;- lazy_dt(data.frame(a = 1))  ## [.data.table dt %>% inner_join(dt2, by = \"a\") %>% show_query() dt %>% right_join(dt2, by = \"a\") %>% show_query() dt %>% left_join(dt2, by = \"a\") %>% show_query() dt %>% anti_join(dt2, by = \"a\") %>% show_query()  ## merge() dt %>% full_join(dt2, by = \"a\") %>% show_query()  # \u0413\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0430 keyby dt %>% group_by(a) %>% summarise(b = mean(b)) %>% show_query()  # \u041a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 \u0432\u044b\u0437\u043e\u0432\u043e\u0432 dt %>%    filter(a == 1) %>%    select(-a) %>%    show_query()  dt %>%    group_by(a) %>%    filter(b &lt; mean(b)) %>%    summarise(c = max(c)) %>%    show_query()<\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"dbplyr\" id=\"dbplyr\"><\/a><\/p>\n<h3>dbplyr<\/h3>\n<p>\u0426\u0435\u043b\u044c <code>dbplyr<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u0432\u0430\u043c \u043c\u0430\u043d\u0438\u043f\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u043c\u0438, \u0445\u0440\u0430\u043d\u044f\u0449\u0438\u043c\u0438\u0441\u044f \u0432 \u0443\u0434\u0430\u043b\u0451\u043d\u043d\u044b\u0445 \u0431\u0430\u0437\u0430\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u0442\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0435\u0441\u043b\u0438 \u0431\u044b \u043e\u043d\u0438 \u0431\u044b\u043b\u0438 \u0434\u0430\u0442\u0430 \u0444\u0440\u0435\u0439\u043c\u0430\u043c\u0438 \u0432 \u0441\u0440\u0435\u0434\u0435 R. \u0414\u0430\u043d\u043d\u044b\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442 \u0433\u043b\u0430\u0433\u043e\u043b\u044b <code>dplyr<\/code> \u0432 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u044b SQL.<\/p>\n<h4>\u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 dbplyr<\/h4>\n<ul>\n<li>\n<p><code>DBI<\/code> &#8212; \u0434\u043b\u044f \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043a \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445;<\/p>\n<\/li>\n<li>\n<p><code>tbl()<\/code> &#8212; \u0434\u043b\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043a \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435;<\/p>\n<\/li>\n<li>\n<p><code>dplyr<\/code> &#8212; \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0432\u0441\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 <code>dplyr<\/code> , \u043d\u0430 \u0434\u0430\u043d\u043d\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u0438\u0434\u0451\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0446\u0435\u043d\u043a\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439;<\/p>\n<\/li>\n<li>\n<p><code>show_query()<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u0439 SQL \u0437\u0430\u043f\u0440\u043e\u0441 \u0431\u0443\u0434\u0435\u0442 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0439 \u043d\u0430 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u043c \u0448\u0430\u0433\u0435 \u043a\u043e\u0434;<\/p>\n<\/li>\n<li>\n<p><code>collect()<\/code> &#8212; \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f, \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442.<\/p>\n<\/li>\n<\/ul>\n<h4>\u041f\u0440\u0438\u043c\u0435\u0440 \u043a\u043e\u0434\u0430 dbplyr<\/h4>\n<details class=\"spoiler\">\n<summary>\u041f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0441 dbplyr<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"r\">library(dplyr) library(dbplyr) library(dplyr, warn.conflicts = FALSE)  con &lt;- DBI::dbConnect(RSQLite::SQLite(), \":memory:\") copy_to(con, mtcars)  # \u043e\u0431\u0440\u0430\u0449\u0430\u0435\u043c\u0441\u044f \u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0435 mtcars2 &lt;- tbl(con, \"mtcars\") # \u043f\u043e\u043a\u0430 \u0447\u0442\u043e \u044d\u0442\u043e \u0432\u0441\u0435\u0433\u043e \u043b\u0438\u0448\u044c \u043e\u0446\u0435\u043d\u043a\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f mtcars2  # dbplyr \u0432 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438 ## \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430 summary &lt;- mtcars2 %>%    group_by(cyl) %>%    summarise(mpg = mean(mpg, na.rm = TRUE)) %>%    arrange(desc(mpg))  ## \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 summary %>% show_query()  ## \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0438 \u0438\u0437\u0432\u043b\u0435\u0447\u0435\u043d\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 summary %>% collect()   # \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 ------------------------------------ mf &lt;- memdb_frame(x = 1, y = 2)  mf %>%    mutate(     a = y * x,      b = a ^ 2,   ) %>%    show_query()   # \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0435 dplyr \u0444\u0443\u043d\u043a\u0446\u0438\u0438 ----------------------------------------------- # \u043b\u044e\u0431\u0430\u044f \u043d\u0435\u0438\u0437\u0432\u0435\u0442\u0441\u043d\u0430\u044f dplyr \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432 \u0437\u0430\u043f\u0440\u043e\u0441 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u043e\u043a\u0438\u043d\u0443\u0442\u0430 \u043a\u0430\u043a \u0435\u0441\u0442\u044c mf %>%    mutate(z = foofify(x, y)) %>%    show_query()  mf %>%    mutate(z = FOOFIFY(x, y)) %>%    show_query()  # \u0442\u0430\u043a \u0436\u0435 dbplyr \u0443\u043c\u0435\u0435\u0442 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u044c \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 mf %>%    filter(x %LIKE% \"%foo%\") %>%    show_query()   # \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0430\u043c\u043e\u043f\u0438\u0441\u043d\u044b\u0439 SQL --------------------------------------------- ## \u0434\u043b\u044f \u0432\u0441\u0442\u0430\u0432\u043a\u0438 SQL \u043a\u043e\u0434\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 sql() mf %>%    transmute(factorial = sql(\"CAST(x AS FLOAT)\")) %>%    show_query()  mf %>%    filter(x == sql(\"ANY VALUES(1, 2, 3)\")) %>%    show_query() <\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"multidplyr\" id=\"multidplyr\"><\/a><\/p>\n<h3>multidplyr<\/h3>\n<p>\u0426\u0435\u043b\u044c <code>multidplyr<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u0432\u0430\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0432 \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435, \u0440\u0430\u0437\u0434\u0435\u043b\u0438\u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u043d\u0430 \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0447\u0430\u0441\u0442\u0438, \u043a\u0430\u0436\u0434\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0441\u0432\u043e\u0451\u043c \u0443\u0437\u043b\u0435.<\/p>\n<h4>\u0412\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u0440\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445<\/h4>\n<p><code>multidplyr<\/code> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0432\u0430\u043c \u0440\u0430\u0437\u0431\u0438\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0434\u0432\u0443\u043c\u044f \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c\u0438:<\/p>\n<ul>\n<li>\n<p>\u0420\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u0435 \u0443\u0436\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>partition()<\/code>.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043d\u0430 \u0447\u0430\u0441\u0442\u0438 \u0432 \u043c\u043e\u043c\u0435\u043d\u0442 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438.<\/p>\n<\/li>\n<\/ul>\n<h4>\u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 multidplyr<\/h4>\n<ul>\n<li>\n<p><code>new_cluster()<\/code> &#8212; \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0432;<\/p>\n<\/li>\n<li>\n<p><code>partition()<\/code> &#8212; \u0440\u0430\u0437\u0431\u0438\u0432\u0430\u0435\u0442 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0439 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u043d\u0430\u0431\u043e\u0440 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 \u0447\u0430\u0441\u0442\u0438, \u0447\u0442\u043e \u0431\u044b \u043a\u0430\u0436\u0434\u0430\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u043d\u0430 \u0441\u0432\u043e\u0451\u043c \u0443\u0437\u043b\u0435 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430;<\/p>\n<\/li>\n<li>\n<p> <code>cluster_assign_partition()<\/code> &#8212; \u0440\u0430\u0437\u0434\u0435\u043b\u044f\u0435\u0442 \u0432\u0435\u043a\u0442\u043e\u0440 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043d\u0430 \u0447\u0430\u0441\u0442\u0438 \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u0447\u0442\u043e \u0431\u044b \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0443\u0437\u043b\u0443 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430 \u0434\u043e\u0441\u0442\u0430\u043b\u0430\u0441\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432;<\/p>\n<\/li>\n<li>\n<p><code>cluster_send()<\/code> &#8212; \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u043d\u0430 \u0440\u0430\u0437\u043d\u044b \u0443\u0437\u043b\u0430\u0445 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430;<\/p>\n<\/li>\n<li>\n<p><code>party_df()<\/code> &#8212; \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0441\u0435\u043a\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0434\u0430\u0442\u0430 \u0444\u0440\u0435\u0439\u043c;<\/p>\n<\/li>\n<li>\n<p><code>collect()<\/code> &#8212; \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u0435\u043a\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0434\u0430\u0442\u0430 \u0444\u0440\u0435\u0439\u043c \u043a \u043e\u0431\u044b\u0447\u043d\u043e\u043c\u0443 \u0440\u0435\u0436\u0438\u043c\u0443 \u0440\u0430\u0431\u043e\u0442\u044b.<\/p>\n<\/li>\n<\/ul>\n<h4>\u041f\u0440\u0438\u043c\u0435\u0440\u044b \u043a\u043e\u0434\u0430 multidplyr<\/h4>\n<details class=\"spoiler\">\n<summary>\u041f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0441 multidplyr<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"r\">library(multidplyr)  # \u0441\u043e\u0437\u0434\u0430\u0404\u043c \u043a\u043b\u0430\u0441\u0442\u0435\u0440 cluster &lt;- new_cluster(4) cluster  # \u0440\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u0435 \u0444\u0440\u0435\u0439\u043c\u0430 \u043d\u0430 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430 -------------------------------------------- library(nycflights13)  flights1 &lt;- flights %>% group_by(dest) %>% partition(cluster) flights1  # \u0432\u044b\u043f\u043e\u043b\u043d\u00a4\u0435\u043c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u00a4 \u0432 \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435 flight_dest %>%    summarise(delay = mean(dep_delay, na.rm = TRUE), n = n()) %>%    collect()  # \u0447\u0442\u0435\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430\u043c\u0438 ---------------------------------------- # \u0441\u043e\u0437\u0434\u0430\u0404\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e \u043f\u0430\u043f\u043a\u0443 path &lt;- tempfile() dir.create(path) # \u0440\u0430\u0437\u0431\u0438\u0432\u0430\u0435\u043c \u0444\u0430\u0439\u043b \u043f\u043e \u043c\u0435\u0441\u00a4\u0446\u0430\u043c,  # \u0441\u043e\u0445\u0440\u0430\u043d\u00a4\u00a4 \u0434\u0430\u043d\u043d\u044b\u0435 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043c\u0435\u0441\u00a4\u0446\u0430 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0444\u0430\u0439\u043b flights %>%    group_by(month) %>%    group_walk(~ vroom::vroom_write(.x, sprintf(\"%s\/month-%02i.csv\", path, .y$month)))  # \u043d\u0430\u0445\u043e\u0434\u0438\u043c \u0432\u0441\u0435 \u0444\u0430\u0439\u043b\u044b \u0432 \u0434\u0438\u0440\u0435\u043a\u0442\u043e\u0440\u0438\u0438,  # \u0438 \u0434\u0435\u043b\u0438\u043c \u0438\u0445 \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0432\u043e\u0440\u043a\u0435\u0440\u0443 \u0434\u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c (\u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e) \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0444\u0430\u0439\u043b\u043e\u0432 files &lt;- dir(path, full.names = TRUE) cluster_assign_partition(cluster, files = files)  # \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u0444\u0430\u0439\u043b\u044b \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0432\u043e\u0440\u043a\u0435\u0440\u0435  # \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c party_df() \u0434\u043b\u00a4 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u00a4 \u0441\u0435\u043a\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0444\u0440\u0435\u0439\u043c\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 cluster_send(cluster, flights2 &lt;- vroom::vroom(files)) flights2 &lt;- party_df(cluster, \"flights2\") flights2   # \u0433\u043b\u0430\u0433\u043e\u043b\u044b dplyr ----------------------------------------------------------- flights1 %>%    summarise(dep_delay = mean(dep_delay, na.rm = TRUE)) %>%    collect()<\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"choice\" id=\"choice\"><\/a><\/p>\n<h3>\u041a\u0430\u043a\u043e\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u0432\u044b\u0431\u0440\u0430\u0442\u044c<\/h3>\n<ul>\n<li>\n<p>\u041d\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u0441\u0440\u0435\u0434\u043d\u0435\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430 \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0442\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>dtplyr<\/code>, \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0430\u0446\u0438\u044e \u043a\u043e\u0434\u0430 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b, \u043f\u0440\u0438 \u0432\u044b\u0441\u043e\u043a\u043e\u0439 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439.<\/p>\n<\/li>\n<li>\n<p>\u0415\u0441\u043b\u0438 \u0432\u0430\u0448\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u043d\u0430\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0431\u043e\u043b\u0435\u0435 \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0441\u0442\u0440\u043e\u043a, \u0442\u043e \u0435\u0441\u0442\u044c \u0441\u043c\u044b\u0441\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>multidplyr<\/code>, \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u043e\u0432 \u0438 \u043e\u0431\u043c\u0435\u043d \u0434\u0430\u043d\u043d\u044b\u0445 \u043c\u0435\u0436\u0434\u0443 \u043d\u0438\u043c\u0438 \u0432\u044b\u0448\u0435, \u043d\u043e \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0448\u0435. \u041d\u043e \u0442\u0443\u0442 \u043d\u0430\u0434\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u0432 \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043e\u043b\u0436\u043d\u0430 \u0431\u044b\u0442\u044c \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f, \u0438\u043c\u0435\u044e\u0449\u0430\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0443\u0440\u043e\u0432\u043d\u0435\u0439, \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u043f\u043e \u044d\u0442\u043e\u0439 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0432\u0430\u0448\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f. \u0415\u0441\u043b\u0438 \u0442\u0430\u043a\u043e\u0439 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u043d\u0435\u0442, \u0442\u043e \u0438 \u043e\u0441\u043e\u0431\u043e \u043f\u0440\u0438\u0440\u043e\u0441\u0442\u0430 \u0432 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 <code>multidplyr<\/code> \u043d\u0435 \u0434\u0430\u0441\u0442, \u0438 \u0434\u0430\u0436\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u0435\u043d \u043e\u0431\u0440\u0430\u0442\u043d\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043f\u0440\u0435\u0432\u044b\u0441\u044f\u0442 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0432 \u043e\u0434\u043d\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435.<\/p>\n<\/li>\n<li>\n<p>\u041a <code>dbplyr<\/code> \u0441\u0442\u043e\u0438\u0442 \u043f\u0440\u0438\u0431\u0435\u0433\u0430\u0442\u044c \u0432 \u0441\u043b\u0443\u0447\u0430\u0435, \u043a\u043e\u0433\u0434\u0430 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0432\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442\u0435 \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0432 \u0431\u0430\u0437\u0430\u0445 \u0434\u0430\u043d\u043d\u044b\u0445. \u0414\u0430\u043d\u043d\u044b\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d \u043d\u0435 \u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u043f\u043e\u0432\u044b\u0448\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u0431\u044b \u0432\u0430\u0448 R \u043a\u043e\u0434 \u043d\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0438\u0432\u0430\u043b\u0441\u044f \u0441 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438.<\/p>\n<\/li>\n<\/ul>\n<p><a class=\"anchor\" name=\"conclusion\" id=\"conclusion\"><\/a><\/p>\n<h2>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n<p>\u0412 \u0445\u043e\u0434\u0435 \u044d\u0442\u043e\u0433\u043e \u0443\u0440\u043e\u043a\u0430, \u043c\u044b \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0441 \u0442\u0435\u043c, \u043a\u0430\u043a \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>dplyr<\/code> \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 \u043d\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430, \u0430 \u0442\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0445\u0440\u0430\u043d\u044f\u0449\u0438\u043c\u0438\u0441\u044f \u0432 \u0431\u0430\u0437\u0430\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u043d\u0435 \u0437\u0430\u0441\u043e\u0440\u044f\u044f \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043a\u043e\u0434 \u0433\u0440\u043e\u043c\u043e\u0437\u0434\u043a\u0438\u043c\u0438 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438.<\/p>\n<p>\u041d\u0430\u0434\u0435\u044e\u0441\u044c \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u0432 \u044d\u0442\u043e\u043c \u0432\u0438\u0434\u0435\u043e \u0443\u0440\u043e\u043a\u0435 \u0431\u044b\u043b \u0432\u0430\u043c \u043f\u043e\u043b\u0435\u0437\u0435\u043d!<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/665680\/\"> https:\/\/habr.com\/ru\/post\/665680\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><code>dplyr<\/code> \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 \u0434\u043b\u044f \u044f\u0437\u044b\u043a\u0430 R, \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u043c \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0443\u0434\u043e\u0431\u043e\u0447\u0438\u0442\u0430\u0435\u043c\u044b\u0439 \u0438 \u043f\u043e\u043d\u044f\u0442\u043d\u044b\u0439 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441. \u0418\u0437 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043a\u043e\u0432 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u0430\u043a\u0435\u0442\u0430 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u043f\u0440\u0438 \u0440\u0430\u0431\u043e\u0442\u0435 \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430 \u043e\u043d \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0443\u0441\u0442\u0443\u043f\u0430\u0435\u0442 \u0432 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 <code>data.table<\/code>.<\/p>\n<p>\u0412 \u044d\u0442\u043e\u043c \u0432\u0438\u0434\u0435\u043e \u0443\u0440\u043e\u043a\u0435 \u043c\u044b \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c\u0441\u044f \u0441 \u0442\u0435\u043c, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043d\u0430 <code>dplyr<\/code>, \u0437\u0430 \u0441\u0447\u0451\u0442 \u0431\u0435\u043a\u0435\u043d\u0434\u043e\u0432 <code>dtplyr<\/code> \u0438 <code>multidplyr<\/code>, \u0430 \u0442\u0430\u043a \u0436\u0435 \u0443\u0437\u043d\u0430\u0435\u043c \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u0438 \u0437\u0430\u0447\u0435\u043c \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0431\u0435\u043a\u0435\u043d\u0434 <code>dbplyr<\/code>, \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044b\u0439 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0431\u0430\u0437\u0430\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<h2>\u0421\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435<\/h2>\n<p><em>\u0415\u0441\u043b\u0438 \u0432\u044b \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u0435\u0442\u0435\u0441\u044c \u0430\u043d\u0430\u043b\u0438\u0437\u043e\u043c \u0434\u0430\u043d\u043d\u044b\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u0432\u0430\u043c \u0431\u0443\u0434\u0443\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u044b \u043c\u043e\u0438\u00a0<\/em><a href=\"https:\/\/t.me\/R4marketing\" rel=\"noopener noreferrer nofollow\"><em>telegram<\/em><\/a><em>\u00a0\u0438\u00a0<\/em><a href=\"https:\/\/www.youtube.com\/R4marketing\/?sub_confirmation=1\" rel=\"noopener noreferrer nofollow\"><em>youtube<\/em><\/a><em>\u00a0\u043a\u0430\u043d\u0430\u043b\u044b. \u0411\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u044b \u044f\u0437\u044b\u043a\u0443 R.<\/em>  <\/p>\n<ol>\n<li>\n<p><a href=\"#video\" rel=\"noopener noreferrer nofollow\">\u0412\u0438\u0434\u0435\u043e<\/a><\/p>\n<ol>\n<li>\n<p><a href=\"#time_code\" rel=\"noopener noreferrer nofollow\">\u0422\u0430\u0439\u043c \u043a\u043e\u0434\u044b<\/a><\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#presentation\" rel=\"noopener noreferrer nofollow\">\u041f\u0440\u0435\u0437\u0435\u043d\u0442\u0430\u0446\u0438\u044f<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#conspekt\" rel=\"noopener noreferrer nofollow\">\u041a\u0440\u0430\u0442\u043a\u0438\u0439 \u043a\u043e\u043d\u0441\u043f\u0435\u043a\u0442<\/a><\/p>\n<ol>\n<li>\n<p><a href=\"#dtplyr\" rel=\"noopener noreferrer nofollow\">dtplyr<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#dbplyr\" rel=\"noopener noreferrer nofollow\">dbplyr<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#multidplyr\" rel=\"noopener noreferrer nofollow\">multidplyr<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"#choice\" rel=\"noopener noreferrer nofollow\">\u041a\u0430\u043a\u043e\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u0432\u044b\u0431\u0440\u0430\u0442\u044c<\/a><\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#conclusion\" rel=\"noopener noreferrer nofollow\">\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/a><\/p>\n<\/li>\n<\/ol>\n<p><a class=\"anchor\" name=\"video\" id=\"video\"><\/a><\/p>\n<h2>\u0412\u0438\u0434\u0435\u043e<\/h2>\n<div class=\"tm-iframe_temp\" data-src=\"https:\/\/embedd.srv.habr.com\/iframe\/6285f8b007a8cd4fd1f4b5fa\" data-style=\"\" id=\"6285f8b007a8cd4fd1f4b5fa\" width=\"\"><\/div>\n<p><a class=\"anchor\" name=\"time_code\" id=\"time_code\"><\/a><\/p>\n<h3>\u0422\u0430\u0439\u043c \u043a\u043e\u0434\u044b:<\/h3>\n<ul>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=0s\" rel=\"noopener noreferrer nofollow\">00:00<\/a> \u0412\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=59s\" rel=\"noopener noreferrer nofollow\">00:59<\/a> \u041a\u0430\u043a\u0438\u0435 \u0431\u0435\u043a\u0435\u043d\u0434\u044b \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=108s\" rel=\"noopener noreferrer nofollow\">01:48<\/a> \u0426\u0435\u043b\u044c <code>dtplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=150s\" rel=\"noopener noreferrer nofollow\">02:30<\/a> \u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <code>dtplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=213s\" rel=\"noopener noreferrer nofollow\">03:33<\/a> \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <code>dtplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=338s\" rel=\"noopener noreferrer nofollow\">05:38<\/a> \u041a\u0430\u043a \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 <code>dplyr<\/code> \u0432 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <code>data.table<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=471s\" rel=\"noopener noreferrer nofollow\">07:51<\/a> \u0424\u0443\u043d\u043a\u0446\u0438\u044f <code>show_query()<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=687s\" rel=\"noopener noreferrer nofollow\">11:27<\/a> \u041f\u043e\u0447\u0435\u043c\u0443 dtplyr \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435 \u0447\u0435\u043c <code>data,table<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=804s\" rel=\"noopener noreferrer nofollow\">13:24<\/a> \u0426\u0435\u043b\u044c <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=820s\" rel=\"noopener noreferrer nofollow\">13:40<\/a> \u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=877s\" rel=\"noopener noreferrer nofollow\">14:37<\/a> \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1014s\" rel=\"noopener noreferrer nofollow\">16:54<\/a> \u041f\u0435\u0440\u0435\u0432\u043e\u0434 <code>dplyr<\/code> \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 \u0432 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u044b <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1073s\" rel=\"noopener noreferrer nofollow\">17:53<\/a> \u041a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432 <code>dbplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1105s\" rel=\"noopener noreferrer nofollow\">18:25<\/a> \u041f\u0435\u0440\u0435\u0432\u043e\u0434 \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 R \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0438 \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u043e\u0432 \u0432 SQL \u0437\u0430\u043f\u0440\u043e\u0441 <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1188s\" rel=\"noopener noreferrer nofollow\">19:48<\/a> \u041f\u0440\u043e\u0431\u0440\u043e\u0441 SQL \u043a\u043e\u043c\u0430\u043d\u0434 \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u044b <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1215s\" rel=\"noopener noreferrer nofollow\">20:15<\/a> \u041a\u0430\u043a \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0432\u043d\u0443\u0442\u0440\u0438 <code>dplyr<\/code> \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 \u0432 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0444\u0443\u043d\u043a\u0446\u0438\u044f <code>translate_sql()<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1286s\" rel=\"noopener noreferrer nofollow\">21:26<\/a> \u0412\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0432 <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1337s\" rel=\"noopener noreferrer nofollow\">22:17<\/a> \u0412\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1370s\" rel=\"noopener noreferrer nofollow\">22:50<\/a> \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1704s\" rel=\"noopener noreferrer nofollow\">28:24<\/a> \u041a\u0430\u043a\u043e\u0439 \u043f\u0430\u043a\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>dtplyr<\/code> \u0438\u043b\u0438 <code>multidplyr<\/code> <\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.youtube.com\/watch?v=Af5ZIAPMjJs&amp;t=1767s\" rel=\"noopener noreferrer nofollow\">29:27<\/a> \u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435  <\/p>\n<\/li>\n<\/ul>\n<p><a class=\"anchor\" name=\"presentation\" id=\"presentation\"><\/a><\/p>\n<h2>\u041f\u0440\u0435\u0437\u0435\u043d\u0442\u0430\u0446\u0438\u044f<\/h2>\n<div class=\"tm-iframe_temp\" data-src=\"https:\/\/embedd.srv.habr.com\/iframe\/627f66cc15db00b4622648ae\" data-style=\"\" id=\"627f66cc15db00b4622648ae\" width=\"\"><\/div>\n<p><a class=\"anchor\" name=\"conspekt\" id=\"conspekt\"><\/a><\/p>\n<h2>\u041a\u0440\u0430\u0442\u043a\u0438\u0439 \u043a\u043e\u043d\u0441\u043f\u0435\u043a\u0442<\/h2>\n<p><a class=\"anchor\" name=\"dtplyr\" id=\"dtplyr\"><\/a><\/p>\n<h3>dtplyr<\/h3>\n<p>\u0426\u0435\u043b\u044c <code>dtplyr<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u0432\u0430\u043c \u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434 dplyr, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u0442\u0440\u0430\u043d\u0441\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 \u044d\u043a\u0432\u0438\u0432\u0430\u043b\u0435\u043d\u0442\u043d\u044b\u0439, \u043d\u043e \u0437\u0430\u0447\u0430\u0441\u0442\u0443\u044e \u0431\u043e\u043b\u0435\u0435 \u0431\u044b\u0441\u0442\u0440\u044b\u0439, \u043a\u043e\u0434 <code>data.table<\/code>.<\/p>\n<h4>\u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 dtplyr:<\/h4>\n<ul>\n<li>\n<p><code>lazy_dt()<\/code> &#8212; \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 <code>dtplyr<\/code> \u0434\u043b\u044f \u043b\u0435\u043d\u0438\u0432\u044b\u0445 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 (\u043f\u0435\u0440\u0432\u043e\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435);<\/p>\n<\/li>\n<li>\n<p><code>dplyr<\/code> &#8212; \u0434\u0430\u043b\u0435\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>lazy_dt()<\/code> \u043e\u0431\u044a\u0435\u043a\u0442 \u0441 \u0433\u043b\u0430\u0433\u043e\u043b\u0430\u043c\u0438 <code>dplyr<\/code>, \u0434\u043b\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0438\u043a\u0430\u043a\u0438\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043d\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u044f\u0442\u0441\u044f, \u0430 \u043b\u0438\u0448\u044c \u043e\u0446\u0435\u043d\u0438\u0432\u0430\u044e\u0442\u0441\u044f;<\/p>\n<\/li>\n<li>\n<p><code>show_query()<\/code> &#8212; \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432 \u043a\u0430\u043a\u043e\u0435 <code>data.table<\/code> \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u044b \u0432\u0430\u0448\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f;<\/p>\n<\/li>\n<li>\n<p><code>as.data.table()<\/code> \/ <code>as.data.frame()<\/code> \/ <code>as_tibble()<\/code> &#8212; \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f, \u0438 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043a \u0442\u043e\u043c\u0443 \u0442\u0438\u043f\u0443, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0432\u044b\u0431\u0440\u0430\u043d\u043d\u043e\u0439 \u0432\u0430\u043c\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0438.<\/p>\n<\/li>\n<\/ul>\n<h4>\u041f\u0440\u0438\u043c\u0435\u0440\u044b \u043a\u043e\u0434\u0430 dtplyr<\/h4>\n<details class=\"spoiler\">\n<summary>\u041f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u0438\u0439 \u0441 dtplyr<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"r\"># dtplyr library(data.table) library(dtplyr) library(dplyr, warn.conflicts = FALSE)  # dtplyr \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043b\u0435\u043d\u0438\u0432\u044b\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f mtcars2 &lt;- lazy_dt(mtcars)  # \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 mtcars2 %>%    filter(wt &lt; 5) %>%    mutate(l100k = 235.21 \/ mpg) %>% # liters \/ 100 km   group_by(cyl) %>%    summarise(l100k = mean(l100k))  # \u043d\u043e \u0434\u043b\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c #  as.data.table(), as.data.frame() \u0438\u043b\u0438 as_tibble() mtcars2 %>%    filter(wt &lt; 5) %>%    mutate(l100k = 235.21 \/ mpg) %>% # liters \/ 100 km   group_by(cyl) %>%    summarise(l100k = mean(l100k)) %>%    as_tibble()  # \u0431\u043e\u043b\u0435\u0435 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u043a\u043e\u0434\u0430 df &lt;- data.frame(a = 1:5, b = 1:5, c = 1:5, d = 1:5) dt &lt;- lazy_dt(df)  # \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u0440\u0435\u0434\u0432\u0430\u0440\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e \u043e\u0446\u0435\u043d\u043a\u0443 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0430 dt # \u0435\u0441\u043b\u0438 \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u0435 \u0432\u044b\u0440\u0430\u0436\u0435\u043d\u0438\u0435 data.table # \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d \u043a\u043e\u0434 dplyr \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c show_query() dt %>% show_query()  # \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0433\u043b\u0430\u0433\u043e\u043b\u044b  ## filter() \/ arrange() - i dt %>% arrange(a, b, c) %>% show_query() dt %>% filter(b == c) %>% show_query() dt %>% filter(b == c, c == d) %>% show_query()  ## select(), summarise(),transmute() - j dt %>% select(a:b) %>% show_query() dt %>% summarise(a = mean(a)) %>% show_query() dt %>% transmute(a2 = a * 2) %>% show_query()  ## mutate - j + := dt %>% mutate(a2 = a * 2, b2 = b * 2) %>% show_query()  # \u0414\u0440\u0443\u0433\u0438\u0435 \u0433\u043b\u0430\u0433\u043e\u043b\u044b dplyr ## rename - setnames dt %>% rename(x = a, y = b) %>% show_query() ## distinct - unique dt %>% distinct() %>% show_query() dt %>% distinct(a, b) %>% show_query() dt %>% distinct(a, b, .keep_all = TRUE) %>% show_query()  # \u041e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f dt2 &lt;- lazy_dt(data.frame(a = 1))  ## [.data.table dt %>% inner_join(dt2, by = \"a\") %>% show_query() dt %>% right_join(dt2, by = \"a\") %>% show_query() dt %>% left_join(dt2, by = \"a\") %>% show_query() dt %>% anti_join(dt2, by = \"a\") %>% show_query()  ## merge() dt %>% full_join(dt2, by = \"a\") %>% show_query()  # \u0413\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0430 keyby dt %>% group_by(a) %>% summarise(b = mean(b)) %>% show_query()  # \u041a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 \u0432\u044b\u0437\u043e\u0432\u043e\u0432 dt %>%    filter(a == 1) %>%    select(-a) %>%    show_query()  dt %>%    group_by(a) %>%    filter(b &lt; mean(b)) %>%    summarise(c = max(c)) %>%    show_query()<\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"dbplyr\" id=\"dbplyr\"><\/a><\/p>\n<h3>dbplyr<\/h3>\n<p>\u0426\u0435\u043b\u044c <code>dbplyr<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u0432\u0430\u043c \u043c\u0430\u043d\u0438\u043f\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u043c\u0438, \u0445\u0440\u0430\u043d\u044f\u0449\u0438\u043c\u0438\u0441\u044f \u0432 \u0443\u0434\u0430\u043b\u0451\u043d\u043d\u044b\u0445 \u0431\u0430\u0437\u0430\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u0442\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0435\u0441\u043b\u0438 \u0431\u044b \u043e\u043d\u0438 \u0431\u044b\u043b\u0438 \u0434\u0430\u0442\u0430 \u0444\u0440\u0435\u0439\u043c\u0430\u043c\u0438 \u0432 \u0441\u0440\u0435\u0434\u0435 R. \u0414\u0430\u043d\u043d\u044b\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442 \u0433\u043b\u0430\u0433\u043e\u043b\u044b <code>dplyr<\/code> \u0432 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u044b SQL.<\/p>\n<h4>\u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 dbplyr<\/h4>\n<ul>\n<li>\n<p><code>DBI<\/code> &#8212; \u0434\u043b\u044f \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043a \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445;<\/p>\n<\/li>\n<li>\n<p><code>tbl()<\/code> &#8212; \u0434\u043b\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043a \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435;<\/p>\n<\/li>\n<li>\n<p><code>dplyr<\/code> &#8212; \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0432\u0441\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 <code>dplyr<\/code> , \u043d\u0430 \u0434\u0430\u043d\u043d\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u0438\u0434\u0451\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0446\u0435\u043d\u043a\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439;<\/p>\n<\/li>\n<li>\n<p><code>show_query()<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u0439 SQL \u0437\u0430\u043f\u0440\u043e\u0441 \u0431\u0443\u0434\u0435\u0442 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0439 \u043d\u0430 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u043c \u0448\u0430\u0433\u0435 \u043a\u043e\u0434;<\/p>\n<\/li>\n<li>\n<p><code>collect()<\/code> &#8212; \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f, \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442.<\/p>\n<\/li>\n<\/ul>\n<h4>\u041f\u0440\u0438\u043c\u0435\u0440 \u043a\u043e\u0434\u0430 dbplyr<\/h4>\n<details class=\"spoiler\">\n<summary>\u041f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0441 dbplyr<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"r\">library(dplyr) library(dbplyr) library(dplyr, warn.conflicts = FALSE)  con &lt;- DBI::dbConnect(RSQLite::SQLite(), \":memory:\") copy_to(con, mtcars)  # \u043e\u0431\u0440\u0430\u0449\u0430\u0435\u043c\u0441\u044f \u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0435 mtcars2 &lt;- tbl(con, \"mtcars\") # \u043f\u043e\u043a\u0430 \u0447\u0442\u043e \u044d\u0442\u043e \u0432\u0441\u0435\u0433\u043e \u043b\u0438\u0448\u044c \u043e\u0446\u0435\u043d\u043a\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f mtcars2  # dbplyr \u0432 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438 ## \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430 summary &lt;- mtcars2 %>%    group_by(cyl) %>%    summarise(mpg = mean(mpg, na.rm = TRUE)) %>%    arrange(desc(mpg))  ## \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 summary %>% show_query()  ## \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0438 \u0438\u0437\u0432\u043b\u0435\u0447\u0435\u043d\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 summary %>% collect()   # \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 ------------------------------------ mf &lt;- memdb_frame(x = 1, y = 2)  mf %>%    mutate(     a = y * x,      b = a ^ 2,   ) %>%    show_query()   # \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0435 dplyr \u0444\u0443\u043d\u043a\u0446\u0438\u0438 ----------------------------------------------- # \u043b\u044e\u0431\u0430\u044f \u043d\u0435\u0438\u0437\u0432\u0435\u0442\u0441\u043d\u0430\u044f dplyr \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u0432 \u0437\u0430\u043f\u0440\u043e\u0441 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u043e\u043a\u0438\u043d\u0443\u0442\u0430 \u043a\u0430\u043a \u0435\u0441\u0442\u044c mf %>%    mutate(z = foofify(x, y)) %>%    show_query()  mf %>%    mutate(z = FOOFIFY(x, y)) %>%    show_query()  # \u0442\u0430\u043a \u0436\u0435 dbplyr \u0443\u043c\u0435\u0435\u0442 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u0442\u044c \u0438\u043d\u0444\u0438\u043a\u0441\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 mf %>%    filter(x %LIKE% \"%foo%\") %>%    show_query()   # \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0430\u043c\u043e\u043f\u0438\u0441\u043d\u044b\u0439 SQL --------------------------------------------- ## \u0434\u043b\u044f \u0432\u0441\u0442\u0430\u0432\u043a\u0438 SQL \u043a\u043e\u0434\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 sql() mf %>%    transmute(factorial = sql(\"CAST(x AS FLOAT)\")) %>%    show_query()  mf %>%    filter(x == sql(\"ANY VALUES(1, 2, 3)\")) %>%    show_query() <\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"multidplyr\" id=\"multidplyr\"><\/a><\/p>\n<h3>multidplyr<\/h3>\n<p>\u0426\u0435\u043b\u044c <code>multidplyr<\/code> &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u0432\u0430\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0432 \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435, \u0440\u0430\u0437\u0434\u0435\u043b\u0438\u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u043d\u0430 \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0447\u0430\u0441\u0442\u0438, \u043a\u0430\u0436\u0434\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0441\u0432\u043e\u0451\u043c \u0443\u0437\u043b\u0435.<\/p>\n<h4>\u0412\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u0440\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445<\/h4>\n<p><code>multidplyr<\/code> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0432\u0430\u043c \u0440\u0430\u0437\u0431\u0438\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0434\u0432\u0443\u043c\u044f \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c\u0438:<\/p>\n<ul>\n<li>\n<p>\u0420\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u0435 \u0443\u0436\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>partition()<\/code>.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043d\u0430 \u0447\u0430\u0441\u0442\u0438 \u0432 \u043c\u043e\u043c\u0435\u043d\u0442 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438.<\/p>\n<\/li>\n<\/ul>\n<h4>\u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 multidplyr<\/h4>\n<ul>\n<li>\n<p><code>new_cluster()<\/code> &#8212; \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0432;<\/p>\n<\/li>\n<li>\n<p><code>partition()<\/code> &#8212; \u0440\u0430\u0437\u0431\u0438\u0432\u0430\u0435\u0442 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0439 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u043d\u0430\u0431\u043e\u0440 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 \u0447\u0430\u0441\u0442\u0438, \u0447\u0442\u043e \u0431\u044b \u043a\u0430\u0436\u0434\u0430\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u043d\u0430 \u0441\u0432\u043e\u0451\u043c \u0443\u0437\u043b\u0435 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430;<\/p>\n<\/li>\n<li>\n<p> <code>cluster_assign_partition()<\/code> &#8212; \u0440\u0430\u0437\u0434\u0435\u043b\u044f\u0435\u0442 \u0432\u0435\u043a\u0442\u043e\u0440 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043d\u0430 \u0447\u0430\u0441\u0442\u0438 \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u0447\u0442\u043e \u0431\u044b \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0443\u0437\u043b\u0443 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430 \u0434\u043e\u0441\u0442\u0430\u043b\u0430\u0441\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432;<\/p>\n<\/li>\n<li>\n<p><code>cluster_send()<\/code> &#8212; \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u043d\u0430 \u0440\u0430\u0437\u043d\u044b \u0443\u0437\u043b\u0430\u0445 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430;<\/p>\n<\/li>\n<li>\n<p><code>party_df()<\/code> &#8212; \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0441\u0435\u043a\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0434\u0430\u0442\u0430 \u0444\u0440\u0435\u0439\u043c;<\/p>\n<\/li>\n<li>\n<p><code>collect()<\/code> &#8212; \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u0435\u043a\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0434\u0430\u0442\u0430 \u0444\u0440\u0435\u0439\u043c \u043a \u043e\u0431\u044b\u0447\u043d\u043e\u043c\u0443 \u0440\u0435\u0436\u0438\u043c\u0443 \u0440\u0430\u0431\u043e\u0442\u044b.<\/p>\n<\/li>\n<\/ul>\n<h4>\u041f\u0440\u0438\u043c\u0435\u0440\u044b \u043a\u043e\u0434\u0430 multidplyr<\/h4>\n<details class=\"spoiler\">\n<summary>\u041f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 \u0441 multidplyr<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"r\">library(multidplyr)  # \u0441\u043e\u0437\u0434\u0430\u0404\u043c \u043a\u043b\u0430\u0441\u0442\u0435\u0440 cluster &lt;- new_cluster(4) cluster  # \u0440\u0430\u0437\u0431\u0438\u0435\u043d\u0438\u0435 \u0444\u0440\u0435\u0439\u043c\u0430 \u043d\u0430 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430 -------------------------------------------- library(nycflights13)  flights1 &lt;- flights %>% group_by(dest) %>% partition(cluster) flights1  # \u0432\u044b\u043f\u043e\u043b\u043d\u00a4\u0435\u043c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u00a4 \u0432 \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435 flight_dest %>%    summarise(delay = mean(dep_delay, na.rm = TRUE), n = n()) %>%    collect()  # \u0447\u0442\u0435\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430\u043c\u0438 ---------------------------------------- # \u0441\u043e\u0437\u0434\u0430\u0404\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e \u043f\u0430\u043f\u043a\u0443 path &lt;- tempfile() dir.create(path) # \u0440\u0430\u0437\u0431\u0438\u0432\u0430\u0435\u043c \u0444\u0430\u0439\u043b \u043f\u043e \u043c\u0435\u0441\u00a4\u0446\u0430\u043c,  # \u0441\u043e\u0445\u0440\u0430\u043d\u00a4\u00a4 \u0434\u0430\u043d\u043d\u044b\u0435 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043c\u0435\u0441\u00a4\u0446\u0430 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0444\u0430\u0439\u043b flights %>%    group_by(month) %>%    group_walk(~ vroom::vroom_write(.x, sprintf(\"%s\/month-%02i.csv\", path, .y$month)))  # \u043d\u0430\u0445\u043e\u0434\u0438\u043c \u0432\u0441\u0435 \u0444\u0430\u0439\u043b\u044b \u0432 \u0434\u0438\u0440\u0435\u043a\u0442\u043e\u0440\u0438\u0438,  # \u0438 \u0434\u0435\u043b\u0438\u043c \u0438\u0445 \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0432\u043e\u0440\u043a\u0435\u0440\u0443 \u0434\u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c (\u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e) \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0444\u0430\u0439\u043b\u043e\u0432 files &lt;- dir(path, full.names = TRUE) cluster_assign_partition(cluster, files = files)  # \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u0444\u0430\u0439\u043b\u044b \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0432\u043e\u0440\u043a\u0435\u0440\u0435  # \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c party_df() \u0434\u043b\u00a4 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u00a4 \u0441\u0435\u043a\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0444\u0440\u0435\u0439\u043c\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 cluster_send(cluster, flights2 &lt;- vroom::vroom(files)) flights2 &lt;- party_df(cluster, \"flights2\") flights2   # \u0433\u043b\u0430\u0433\u043e\u043b\u044b dplyr ----------------------------------------------------------- flights1 %>%    summarise(dep_delay = mean(dep_delay, na.rm = TRUE)) %>%    collect()<\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"choice\" id=\"choice\"><\/a><\/p>\n<h3>\u041a\u0430\u043a\u043e\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u0432\u044b\u0431\u0440\u0430\u0442\u044c<\/h3>\n<ul>\n<li>\n<p>\u041d\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u0441\u0440\u0435\u0434\u043d\u0435\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430 \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0442\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>dtplyr<\/code>, \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0430\u0446\u0438\u044e \u043a\u043e\u0434\u0430 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b, \u043f\u0440\u0438 \u0432\u044b\u0441\u043e\u043a\u043e\u0439 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439.<\/p>\n<\/li>\n<li>\n<p>\u0415\u0441\u043b\u0438 \u0432\u0430\u0448\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u043d\u0430\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0431\u043e\u043b\u0435\u0435 \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0441\u0442\u0440\u043e\u043a, \u0442\u043e \u0435\u0441\u0442\u044c \u0441\u043c\u044b\u0441\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>multidplyr<\/code>, \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u043e\u0432 \u0438 \u043e\u0431\u043c\u0435\u043d \u0434\u0430\u043d\u043d\u044b\u0445 \u043c\u0435\u0436\u0434\u0443 \u043d\u0438\u043c\u0438 \u0432\u044b\u0448\u0435, \u043d\u043e \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0448\u0435. \u041d\u043e \u0442\u0443\u0442 \u043d\u0430\u0434\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u0432 \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043e\u043b\u0436\u043d\u0430 \u0431\u044b\u0442\u044c \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f, \u0438\u043c\u0435\u044e\u0449\u0430\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0443\u0440\u043e\u0432\u043d\u0435\u0439, \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u043f\u043e \u044d\u0442\u043e\u0439 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0432\u0430\u0448\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f. \u0415\u0441\u043b\u0438 \u0442\u0430\u043a\u043e\u0439 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u043d\u0435\u0442, \u0442\u043e \u0438 \u043e\u0441\u043e\u0431\u043e \u043f\u0440\u0438\u0440\u043e\u0441\u0442\u0430 \u0432 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439 <code>multidplyr<\/code> \u043d\u0435 \u0434\u0430\u0441\u0442, \u0438 \u0434\u0430\u0436\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u0435\u043d \u043e\u0431\u0440\u0430\u0442\u043d\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043f\u0440\u0435\u0432\u044b\u0441\u044f\u0442 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0432 \u043e\u0434\u043d\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435.<\/p>\n<\/li>\n<li>\n<p>\u041a <code>dbplyr<\/code> \u0441\u0442\u043e\u0438\u0442 \u043f\u0440\u0438\u0431\u0435\u0433\u0430\u0442\u044c \u0432 \u0441\u043b\u0443\u0447\u0430\u0435, \u043a\u043e\u0433\u0434\u0430 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0432\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442\u0435 \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0432 \u0431\u0430\u0437\u0430\u0445 \u0434\u0430\u043d\u043d\u044b\u0445. \u0414\u0430\u043d\u043d\u044b\u0439 \u0431\u0435\u043a\u0435\u043d\u0434 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d \u043d\u0435 \u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u043f\u043e\u0432\u044b\u0448\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0439, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u0431\u044b \u0432\u0430\u0448 R \u043a\u043e\u0434 \u043d\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0438\u0432\u0430\u043b\u0441\u044f \u0441 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438.<\/p>\n<\/li>\n<\/ul>\n<p><a class=\"anchor\" name=\"conclusion\" id=\"conclusion\"><\/a><\/p>\n<h2>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n<p>\u0412 \u0445\u043e\u0434\u0435 \u044d\u0442\u043e\u0433\u043e \u0443\u0440\u043e\u043a\u0430, \u043c\u044b \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0441 \u0442\u0435\u043c, \u043a\u0430\u043a \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <code>dplyr<\/code> \u0433\u043b\u0430\u0433\u043e\u043b\u043e\u0432 \u043d\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430, \u0430 \u0442\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0445\u0440\u0430\u043d\u044f\u0449\u0438\u043c\u0438\u0441\u044f \u0432 \u0431\u0430\u0437\u0430\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u043d\u0435 \u0437\u0430\u0441\u043e\u0440\u044f\u044f \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043a\u043e\u0434 \u0433\u0440\u043e\u043c\u043e\u0437\u0434\u043a\u0438\u043c\u0438 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438.<\/p>\n<p>\u041d\u0430\u0434\u0435\u044e\u0441\u044c \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b<\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-333345","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/333345","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=333345"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/333345\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=333345"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=333345"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=333345"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}