{ "cells": [ { "cell_type": "markdown", "metadata": { "id": "view-in-github", "colab_type": "text" }, "source": [ "\"Open" ] }, { "cell_type": "markdown", "metadata": { "id": "Z7apiBJbNP0R" }, "source": [ "Son değiştirilme tarihi:21.09.2024" ] }, { "cell_type": "markdown", "metadata": { "id": "r2qH7XpGNP0U" }, "source": [ "ÖNSÖZ" ] }, { "cell_type": "markdown", "metadata": { "id": "N2GwLaANNP0V" }, "source": [ "NOT:Dokümanda zaman zaman güncellemeler olacağı için arada bir güncel versiyon kontrolü yapmanızı tavsiye ederim.\n", "
\n", "\n", "\"nbviewer\" üzerinden görüntülüyorsanız, dosyayı kaydetmek için sayfanın sağ üst köşesindeki download butonuna tıklayın, açılan sayfada herhangi bir yere sağ tıklayın ve `farklı kaydet` diyerek dosyayı istediğiniz klasöre kaydedin. Dosyayı açabilmek için Jupyter'in kurulması gerekmekte olup, yeni başlayan biriyseniz aşağıda kurulumla ilgili detayları inceleyin.\n", "
" ] }, { "cell_type": "markdown", "source": [ "# Kurulumlar" ], "metadata": { "id": "mCZjqiN8QNWi" } }, { "cell_type": "markdown", "metadata": { "id": "FDY8Dhe4NP0X" }, "source": [ "**EDIT(09.2024):** Ben artık sadece [Colab](https://colab.research.google.com/) kullanıyorum. Yapay zeka desteği ile tartışılmaz tek gerekli araç bu olmuştur. İstediğiniz işi basit promptlarla yaptırmak çok kolay.\n", "\n", "\n", "![Ekran Görüntüsü - 2024-09-21 18-32-19.png]()\n", "\n", "Oluştur'a tıkladıktan sonra, promptumuz yazıyorum ve voila!\n", "\n", "![Ekran Görüntüsü - 2024-09-21 18-33-34.png]()\n", "\n", "Colab kullanma imkanı olmayanlar için aşağıdaki eski notlarım geçerlidir.\n", "\n", "
\n", "\n", "Python'a ilk kez başlıyorsanız önce \"Anaconda\" kurulumu yapmanız gerekmektedir. Bu işlemi şu sayfadan öğrenebilir veya hemen alttaki videodan izleyebilirsiniz.\n", "\n", "**NOT: Normalde Anaconda birçok paketi ve programı baırndırdığı için bilgisayarınızda çok yer kaplamakta olup ilerde anacondayı kaldırıp pure python kurulumu yapmanızı, ve sadece ihtyiacınız olan paketleri kurmanızı tavsiye ederim. Ancak herşeyin hazır gelmesi sebebiyle ilk başta anaconda ile başlamanız yerinde oalcaktır. Disk sorununuz yoksa anaconda ile devam da edebilirsiniz.**\n", "\n", "Anaconda ile birlikte Python environment'ına ek olarak Jupyter notebook uygulaması ve Spyder gibi IDE'ler de kurulacaktır. Ayrıca birçok önemli kütüphane(numpy, pandas, sklearn gibi) kurulmuş olacak. Ben de bu dokümanı Jupyter üzerinde hazırladım. O yüzden Jupyter ağırlıklı gideceğiz. Spyder'ı, kurcalayarak ve Youtube'da birkaç video izleyerek kendiniz de öğrenebilirsiniz.\n", "\n", "Bu notebookta detaylı Jupyter kullanımı olmayacak. Her detayı vermekten ziyade bir başucu rehberi hazırlamayı amaçladım. Yani tam bir eğitim dokümanından ziyade büyük bir cheatsheet(hızlı başvuru kaynağı) tadında bir doküman bulacaksınız. Dokümanın en altında süper konsantre bir cheatsheet daha bulacaksınız.\n", "\n", "Gereksiz açıklamalarla dokümanı şişirmek istemedim. Çoğu durumda kodları çalıştırdığınızda neyin ne olduğunu anlayabileceksiniz. Anlaşılması zor durumlar için ilave açıklamalar olacaktır.\n", "\n", "Bununla birlikte bir nebze de olsa programcılık dünyasına aşina olmanızda fayda var. Eğer tamamen sıfır noktasındaysanız bu doküman size biraz ağır gelebilir. Önce başka bir kaynaktan temelleri(değişken, fonksiyon, algoritma, nesne v.s) öğrenin, bu dokümanı ise cheatsheet olarak kullanın." ] }, { "cell_type": "code", "execution_count": 1, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:10:52.681419Z", "start_time": "2021-05-15T15:10:52.225681Z" }, "id": "FTLeQQOGNP0X", "outputId": "09292b1d-37f4-40f4-9ead-888a24b71f92", "colab": { "base_uri": "https://localhost:8080/", "height": 321 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ], "text/html": [ "\n", " \n", " " ], "image/jpeg": "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fw+NPRkv4fGnCy5TonGwZxqsOlZnoyX8PjT0ZL+HxpwsuU6JxsGcarCNWhewfkKhPRkv4fmqbXsH5Cuns6J7C7eFMFxdsTxyBu4QccPZfaVR/W+57sPyv9dPW+57sPyv9dZbyh76LBc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/10vKHvolz2joNVeKVR/W+57sPyv8AXT1vue7D8r/XS8oe+iXPaOg1V4pVH9b7nuw/K/109b7nuw/K/wBdLyh76Jc9o6DVXilUf1vue7D8r/XT1vue7D8r/XS8oe+iXPaOg1VdpSleeXrEpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURKUpREpSlESlKURf/9k=\n" }, "metadata": {}, "execution_count": 1 } ], "source": [ "from IPython.display import YouTubeVideo\n", "YouTubeVideo('JEv5oigBUL0')" ] }, { "cell_type": "markdown", "metadata": { "id": "Y0Q9eLeeNP0Z" }, "source": [ "# Jupyter" ] }, { "cell_type": "markdown", "metadata": { "id": "wNbDnGGmNP0a" }, "source": [ "## Rehber" ] }, { "cell_type": "markdown", "metadata": { "id": "5Qw_PCoqNP0a" }, "source": [ "### Jupyter kullanırken neleri bilmenizde fayda var?" ] }, { "cell_type": "markdown", "metadata": { "id": "LkyZoJggNP0b" }, "source": [ "* Kısayol tuşları(Jupyter'de H tuşuna basınca çıkar)-->bunları mutlaka kullanın, büyük hız kazandırır. Herşeyi yukarıdaki menülerden yapmaya kalkarsanız yavaş ilerlersiniz.\n", "* magic functions(Googlelayın)-->Bir süre sonra, şimdi değil\n", "* smart suggestions(tab, tab+tab)-->sınıflar ve metodlar hakkında bilgi alırsınız, kod pratiğine başlayınca deneyin. Aşağıda print için örnek ekran görüntüleri var.\n", "* nbextensions ve jupyter_helpers-->sol paneldeki içindekiler ve indeksleme dahil birçok güzellik\n", "* help, dir ile yardım alınır-->deneyin(aşağıda örnek var)\n", "* type fonksiyonu ile sık sık bir değişkenin tipini öğrenmeniz gerekecek -->deneyin\n", "* naming convention(pep 0008)-->Kritik değil ama bence önemli, googlelayın\n", "* jupyteri ektin kullanma rehberleri(medium v.s)-->Hemen değil ama bir süre sonra googlelayın\n", "* https://www.dataquest.io/blog/jupyter-notebook-tips-tricks-shortcuts/\n", "* https://towardsdatascience.com/productivity-tips-for-jupyter-python-a3614d70c770" ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "id": "YGarWWj4NP0c", "outputId": "32df3a5a-c32d-4825-ff75-a5075895ed41", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ " \n" ] } ], "source": [ "a=1\n", "liste=[]\n", "print(type(a),type(liste))" ] }, { "cell_type": "code", "execution_count": 3, "metadata": { "id": "Eze8T8J8NP0d", "outputId": "8210c7f1-0e3f-4f5f-dc24-522d3a6d23ba", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Help on built-in function print in module builtins:\n", "\n", "print(...)\n", " print(value, ..., sep=' ', end='\\n', file=sys.stdout, flush=False)\n", " \n", " Prints the values to a stream, or to sys.stdout by default.\n", " Optional keyword arguments:\n", " file: a file-like object (stream); defaults to the current sys.stdout.\n", " sep: string inserted between values, default a space.\n", " end: string appended after the last value, default a newline.\n", " flush: whether to forcibly flush the stream.\n", "\n" ] } ], "source": [ "help(print) #print fonksiyonu hakkında yardım" ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "id": "0Ep6IF5WNP0e", "outputId": "bfda99a0-a755-4341-ccce-85703b543300", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['clear',\n", " 'copy',\n", " 'fromkeys',\n", " 'get',\n", " 'items',\n", " 'keys',\n", " 'pop',\n", " 'popitem',\n", " 'setdefault',\n", " 'update',\n", " 'values']" ] }, "metadata": {}, "execution_count": 4 } ], "source": [ "[x for x in dir(dict) if not \"__\" in x] #dictionary nesnesinin property ve metodları. tek başına dir(dict) yapsaydım\n", "#çok uzun bi liste çıkardı. Biraz aşağıda göreceğimiz 'list comprehension' yönteminden faydalanarak listeyi daralttım" ] }, { "cell_type": "markdown", "metadata": { "id": "EE31_wWENP0f" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "vAN_wAqdNP0f" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "dWpOrXCKNP0f" }, "source": [ "Anacondayı kurduktan sonra yukarda bahsettiğim nbextensionsı kurar ve bu notebooku kendi pcnize indirip jupyter içinden açarsanız aşağıdaki gibi İçindekiler tablolu ve indeksli şekilde görebilirsiniz. Kurulumun nasıl yapılacağını https://jupyter-contrib-nbextensions.readthedocs.io/en/latest/install.html sayfasından görebilirsiniz. Onun öncesinde biraz aşağıdaki Modül, Package, Class bölümüne bakıp kavramlar hakkında kısa bir bilgi edinebilirsiniz. (Bu işlem size karışık gelirse bu aşamayı pas geçebilir ve biraz daha deneyim kazandıktan sonra tekrar denersiniz. Ancak benim tavsiyem, bikaç kez deneyin ve kurmaya çalışın, inanın çok faydasını göreceksiniz)" ] }, { "cell_type": "markdown", "metadata": { "id": "7wfxcfQTNP0f" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "al7V5l2PNP0g" }, "source": [ "NOT: Yukarıdaki ekran görüntüsü gibi resimleri kolayca notebookunuz içine ekleyebiliyorsunuz. Sadece bir Markdown tipli hücre açıp içine girin ve clipboarda aldığınız resmi yapıştırın." ] }, { "cell_type": "markdown", "metadata": { "id": "RlVMY4HwNP0g" }, "source": [ "### Çoklu output" ] }, { "cell_type": "markdown", "metadata": { "id": "sukkjEEUNP0g" }, "source": [ "Normalde bir hücrede \"print\" ifadesi kullanmazsak sadece son değişken çıktı olarak gösterilir. Ancak aşağıdaki kod bloğu ile tüm değişkenler çıktı olarak elde edilebilmektedir.\n", "\n", "
\n",
        "from IPython.core.interactiveshell import InteractiveShell\n",
        "InteractiveShell.ast_node_interactivity = \"all\"\n",
        "
\n", "\n", "Örneğin bu interactive kodları girilmeden aşağıdaki kod çalışıtırılırsa sadece 2 sonucunu alırken\n", "
\n",
        "a=1\n",
        "b=2\n",
        "a\n",
        "b\n",
        "
\n", "\n", "Yukarıdaki iki satırlık kod girilirse hem 1 hem 2 sonucu görünür." ] }, { "cell_type": "code", "execution_count": 5, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:32:54.059281Z", "start_time": "2021-05-15T15:32:54.055292Z" }, "id": "3zhPcl7VNP0h" }, "outputs": [], "source": [ "from IPython.core.interactiveshell import InteractiveShell\n", "InteractiveShell.ast_node_interactivity = \"all\"" ] }, { "cell_type": "code", "execution_count": 6, "metadata": { "id": "RkfLENr4NP0i", "outputId": "07ef44cc-1992-4f73-f19c-33619a12cfe3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "1" ] }, "metadata": {}, "execution_count": 6 }, { "output_type": "execute_result", "data": { "text/plain": [ "2" ] }, "metadata": {}, "execution_count": 6 } ], "source": [ "a=1\n", "b=2\n", "a\n", "b" ] }, { "cell_type": "markdown", "metadata": { "id": "EEPX3axvNP0i" }, "source": [ "## Çeşitli operatörler" ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "id": "rsnrNJINNP0i", "outputId": "678084f6-0737-4a0d-a16e-2c5f3d879975", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "drive sample_data\n" ] } ], "source": [ "#! işareti ile işletim sistemi komutları kullanılabilir. Windows'ta cmd'den, Linux'ta terminalden yazar gibi olur\n", "# !dir #windowsta olsaydım\n", "!ls #colab'te olduğum için, colabde Linux üzerinde çalıştığı için ls" ] }, { "cell_type": "code", "source": [ "!pwd" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "MDmA-sdXCLMF", "outputId": "820a5932-a2e9-4c7a-a9a8-8e6c3c56bb58" }, "execution_count": 8, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/content\n" ] } ] }, { "cell_type": "code", "source": [ "%cd sample_data #! ile dğeil % ile. sebebi: The !cd command only changes the directory for that specific line. To change the directory for the whole notebook, use the %cd command instead.\n", "!ls" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "AZwHtBQDCAYx", "outputId": "1d45d904-00a3-418a-9ff9-d0c157fc5e14" }, "execution_count": 9, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[Errno 2] No such file or directory: 'sample_data #! ile dğeil % ile. sebebi: The !cd command only changes the directory for that specific line. To change the directory for the whole notebook, use the %cd command instead.'\n", "/content\n", "drive sample_data\n" ] } ] }, { "cell_type": "code", "execution_count": 10, "metadata": { "id": "ZbIQGdp4NP0j" }, "outputs": [], "source": [ "# \"#\" işareti ile yorum yazarız" ] }, { "cell_type": "code", "execution_count": 11, "metadata": { "id": "mFFxeJGrNP0j", "outputId": "3aa3274d-fdc9-4619-c9bb-2f2df01be85c", "colab": { "base_uri": "https://localhost:8080/", "height": 34 } }, "outputs": [ { "output_type": "display_data", "data": { "text/plain": [ "" ], "text/html": [ "Farklı dil seçeneklerin kullanabiliyoruz. Burada HTML kullanmış olduk.\n" ] }, "metadata": {} } ], "source": [ "#çeşitli dillerden metin yazılabilir, html, javascript v.s. Bunun için ilgili dil için geçerli olan magic command kullanılır\n", "%%HTML\n", "Farklı dil seçeneklerin kullanabiliyoruz. Burada HTML kullanmış olduk." ] }, { "cell_type": "markdown", "metadata": { "id": "0cRLxshSNP0k" }, "source": [ "## Matematiksel ifadeler" ] }, { "cell_type": "code", "execution_count": 12, "metadata": { "scrolled": true, "id": "Ce2m9Fj8NP0k", "outputId": "539cfb6a-4808-4117-b3cf-b70e8eb2f203", "colab": { "base_uri": "https://localhost:8080/", "height": 52 } }, "outputs": [ { "output_type": "display_data", "data": { "text/plain": [ "" ], "text/latex": "$$E=mc^2$$\n$sin(x)/x$\n" }, "metadata": {} } ], "source": [ "%%latex #Latex ile matematiksel formüller girebiliyoruz\n", "$$E=mc^2$$\n", "$sin(x)/x$" ] }, { "cell_type": "markdown", "metadata": { "id": "T-UEWeG9NP0k" }, "source": [ "Hizalama
\n", "Yukarıdaki code hücresiyidi, bu ise markdown hücresidir
\n", "$$ ile yazım formülü ortalar
\n", "\\$ ile yazımda ise sola dayalı ve küçük
\n", "\n", "$$\\Pi p(n)$$\n", "$$\\Pi \\pi$$\n", "\n", "$\\frac \\pi 2$" ] }, { "cell_type": "markdown", "metadata": { "id": "hiV4Vj6fNP0l" }, "source": [ "Diğer ifadeler\n", "\n", "\\frac ifadesi ile kesirler
\n", "_ karakteri ile indis(subscript)
\n", "\\pi, \\sum, \\bar ve \\hat gibi özel ifadeler
\n", "\n", "$$\\sum p(n)$$\n", "\n", "$$y_i, \\bar{y}_i, \\hat{y}_i$$\n", "\n", "$$TSS=\\sum_{i=1}^n(y_i-\\bar{y}_i)^2$$\n", "\n", "$$P(c|x)=\\frac {P(x|c).P(c)}{P(x)}$$" ] }, { "cell_type": "code", "execution_count": 13, "metadata": { "id": "j5kmptbQNP0l", "outputId": "dc958be6-a850-430f-9cd9-fce3732ab46d", "colab": { "base_uri": "https://localhost:8080/", "height": 57 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ], "text/latex": "$\\displaystyle F(k) = \\int_{-\\infty}^{\\infty} f(x) e^{2\\pi i k} dx$" }, "metadata": {}, "execution_count": 13 } ], "source": [ "#bu modül ile de daha gösterişli matematiksel formüller girebiliyoruz\n", "from IPython.display import Math\n", "Math(r'F(k) = \\int_{-\\infty}^{\\infty} f(x) e^{2\\pi i k} dx')" ] }, { "cell_type": "code", "execution_count": 14, "metadata": { "id": "1G6puqzhNP0m", "outputId": "036f1de0-41bf-4374-fcbb-913469905642", "colab": { "base_uri": "https://localhost:8080/", "height": 61 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ], "text/html": [ "\n", " \n", " " ] }, "metadata": {}, "execution_count": 14 } ], "source": [ "#dahası da var, müzik ve video da ekleyebiliyoruz\n", "from IPython.display import Audio\n", "Audio(url=\"http://www.nch.com.au/acm/8k16bitpcm.wav\")" ] }, { "cell_type": "code", "execution_count": 15, "metadata": { "id": "iYTTHXH5NP0m", "outputId": "17ed7d57-f0f7-4541-9594-251b5d369988", "colab": { "base_uri": "https://localhost:8080/", "height": 321 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ], "text/html": [ "\n", " \n", " " ], "image/jpeg": "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\n" }, "metadata": {}, "execution_count": 15 } ], "source": [ "from IPython.display import YouTubeVideo\n", "YouTubeVideo('agj3AxNPDWU')" ] }, { "cell_type": "markdown", "metadata": { "id": "2GTYZP03NP0n" }, "source": [ "Latex ve Ipython.display hakkında daha fazla bilgi için\n", "\n", "- https://nbviewer.jupyter.org/github/ipython/ipython/blob/2.x/examples/Notebook/Display%20System.ipynb\n", "- https://towardsdatascience.com/write-markdown-latex-in-the-jupyter-notebook-10985edb91fd\n", "- https://stackoverflow.com/questions/13208286/how-to-write-latex-in-ipython-notebook" ] }, { "cell_type": "markdown", "metadata": { "id": "ccCaHGjMNP0o" }, "source": [ "## Genel syntax" ] }, { "cell_type": "code", "execution_count": 16, "metadata": { "id": "WZ3c6eKeNP0o" }, "outputs": [], "source": [ "sayi=1 #değişkenler doğrudan atanır. türkçe karakter kullanmamaya çalışın" ] }, { "cell_type": "markdown", "metadata": { "id": "TPMaeUYPNP0o" }, "source": [ "### Değişkenlerde çoklu satır kullanımı" ] }, { "cell_type": "code", "execution_count": 17, "metadata": { "id": "DXlmk9HbNP0p", "outputId": "cd02598c-a76b-454f-d9b0-c832d35fefd9", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "merhaba burada line contination uygulandıama sonuç yine de bitişik yazar\n" ] } ], "source": [ "linecont=\"merhaba burada line \"+ \\\n", "\" contination uygulandı\" + \\\n", "\"ama sonuç yine de bitişik yazar\"\n", "print(linecont)" ] }, { "cell_type": "code", "execution_count": 18, "metadata": { "id": "OTeWsfftNP0p", "outputId": "1d3f7f7d-4342-44dd-9423-eb0ac8783ee4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n", "bu satırlar\n", "ise satırlara\n", "yayılmış durum\n", "\n" ] } ], "source": [ "satırayaygın=\"\"\"\n", "bu satırlar\n", "ise satırlara\n", "yayılmış durum\n", "\"\"\"\n", "print(satırayaygın)" ] }, { "cell_type": "code", "execution_count": 19, "metadata": { "id": "xPoeFmqrNP0p", "outputId": "53e2ead8-6c38-4476-c230-6fc123564476", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['Pzt', 'salı', 'çar', 'perş']\n" ] } ], "source": [ "#veri yapıları için ise yukarıdaki iki yönteme de gerek olmadan kaydırabiliriz\n", "gunler=[\"Pzt\",\"salı\",\n", " \"çar\",\"perş\"]\n", "print(gunler)" ] }, { "cell_type": "markdown", "metadata": { "id": "Yfwp7ThyNP0q" }, "source": [ "### Başlıklar" ] }, { "cell_type": "markdown", "metadata": { "id": "S3JVHBJUNP0q" }, "source": [ "Başlıklar normalde #, ##, ###,... ifadeleriyle HTML'deki h1,h2,h3...'e denk gelecek şekilde oluşturulur. Bu dokümandaki tüm başlıklar da böyle oluşuturuldu. Dokümanı kendi jupyterinizde açtıysanız, herhangi bir başlık hücresine gelip Enter'a basın. Enter ile hücreyi edit moduna sokmuş oluruz. Böylece başlığın nasıl yazıldığını da görmüş olursunuz. Mesela bu paragrafın başlığı aşağıdaki gibidir" ] }, { "cell_type": "markdown", "metadata": { "id": "4n6D1-n2NP0q" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "nxhWGDtaNP0r" }, "source": [ "Bu tür başlıklar, eğer nbextension kurduysanız 1.1.2 gibi indeksli şekilde görünür. Eğerki bu dokümana bir notebook gösterici(github veya nbviewer gibi) üzerinden bakıyorsanız 1.1.2 şeklindeki gösterimi görmüyorsunuzdur. Detaylar için en baştaki Rehber kısmına bakınız" ] }, { "cell_type": "markdown", "metadata": { "id": "bmfGvWUDNP0r" }, "source": [ "Bu ise html(strong tag'i) kullanılarak oluşturulmuş kalın bi başlık. Sol paneldeki \"İçindekiler\" paneline girmesini istemediğiniz başlıkları bu şekilde oluşturabilirsiniz." ] }, { "cell_type": "markdown", "metadata": { "id": "SJz6PZhCNP0r" }, "source": [ "Diğer başlık türleri\n", "\n", "***üç yıldız ile bold&italik***
\n", "**iki yıldız ile bold yapma**
\n", "*tek yıldız ile italik yapma*
\n", "`sağa dönük tek tırnak ile` vurgulu yapma. Bu karakteri Alt+96 ile yazabilirsiniz." ] }, { "cell_type": "markdown", "metadata": { "id": "GgAukwoINP0r" }, "source": [ "### Paragraf, satır geçme ve html kullanımı" ] }, { "cell_type": "markdown", "metadata": { "id": "_PtCNL1fNP0r" }, "source": [ "Üst paragraf\n", "\n", "İki kere entera basarak paragraf açabilirsiniz(bu satırda olduğu gibi. hücreye çift tıklayın ve görün)
\n", "veya bi satırın sonunda \"br\" tagi ekleyerek bir alt satıra geçebilrsiniz. (bu satırda olduğu gibi. hücreye çift tıklayın ve görün)\n", "\n", "NOT:Bu kolaylıkları öğrenene/keşfedene kadar ben bu paragraf ve bi alt satır işlerini Markdown değil de Raw NB Convert hücre tipi ile yapıyordum. Bunu öğrendikten sonra Raw NB Covnert tipli hücrelere pek ihtiyaç duymadım." ] }, { "cell_type": "markdown", "metadata": { "id": "BURPZ7aQNP0r" }, "source": [ "### Naming convention" ] }, { "cell_type": "markdown", "metadata": { "id": "ZMY65lLwNP0s" }, "source": [ "\"Pep 008 python\" araması yapın ve tüm detayları görün. aşağıda sadece \"_\" kullanımını koydum" ] }, { "cell_type": "code", "execution_count": 20, "metadata": { "id": "aUgXGQjANP0s", "outputId": "1338d0de-e3ab-4d8e-f9a2-67d7a1ff3a38", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "ad\n", "soyad\n" ] } ], "source": [ "_privatevariable=3\n", "#_privatemethod()\n", "list_=[1,2,3] #rezerv keylerin sonuna _ gelir. list diye bir değişken adı kullanamayız, list_ olabilir\n", "dict_={\"ad\":\"ali\",\"soyad\":\"yılmaz\"}\n", "for x,_ in dict_.items(): #ilgilenmediğimiz değerler için \"_\"\n", " print(x)" ] }, { "cell_type": "markdown", "metadata": { "id": "Vl3lloNKNP0t" }, "source": [ "Bununu dışında sklearn(Machine Learning kütüphanesi)de bazı propertylerin _ ile bittiğini görürsünüz. bunların anlamı da, ilgili propertyle ulaşmak için öncelikle modelin eğitilmesi(fit edilmesi) gerekmekte, eğitilmemiş modelde bu bilgiye ulaşamak anlamsızdır demek." ] }, { "cell_type": "markdown", "metadata": { "id": "LUhV93q8NP0t" }, "source": [ "# Modül, Package, Class" ] }, { "cell_type": "markdown", "metadata": { "id": "kg0ki9ZfNP0t" }, "source": [ "Bu 3 kavram hiyerarşik olarak şöyle sıralanır. Package>module>class.\n", "\n", "Yani her sınıf bir modül içindedir. modüller py uzantılı dosylardır. birkaç modül biraraya gelerek bir paket oluşturur. Ör: DataScience çalışmalarında pandas paketi kullanılır, bu anaconda sürümü ile birlikte gelir.\n", "\n", "Bir de kütüphane kavramı var. Python'daki kütüphane(library) kavramı C/C# gibi dillerdeki dll dosyalarından farklı bir anlama sahiptir. Burada daha çok belirli modüllerin veya package'ların biraraya gelerek kavramsal bir topluluk oluşturumasından bahsediyoruz. Ör:Makine öğrenme kütüphanesi gibi. Bu arada ille bir fiziksel karşılık aranacaksa package'lar gibi düşünülebilirler." ] }, { "cell_type": "markdown", "metadata": { "id": "G-2im5BGNP0t" }, "source": [ "**DİKKAT:Kafa karışıtırıcı bir paragraf, isterseniz şimdilik atlayın ma sonra mutlaka glin ve özellikle alttaki linki okuyun**\n", "\n", "Yeni bir paket kurmak istediğinizde;\n", "\n", "conda install paketadı demeniz yeterlidir. Eğer bu yeterli gelmezse;
\n", "pip install paketadı diyebilirsiniz. Bunu bazen başında ! olacak şekilde yapmak gerekebiliyor. ! varsa aslında komut satırı komutu gibi çalışmış oluyor, ! yoksa da % işareti varmış gibi çalışıyor. % işareti olması automagic olarak çalışması anlmamına gleiyor. automagic konusunu araştırrsanız anlarsınız.\n", "\n", "Ama şimdi bu yukarıdaki iki yöntemi de unutun ve aşağıdaki şu linke bakın. kurulumları nasıl yapmanız gerektiğini göreceksiniz.\n", "\n", "Daha detaylı bilgiyi aşağıdaki linkten edinebilirsiniz:
\n", "https://jakevdp.github.io/blog/2017/12/05/installing-python-packages-from-jupyter/" ] }, { "cell_type": "code", "source": [ "#uzun uzun kurulum bilgisi yazmasın diye -q ekleriz\n", "!pip -q install forbiddenfruit" ], "metadata": { "id": "y1w7BXFDFdxC" }, "execution_count": 21, "outputs": [] }, { "cell_type": "code", "execution_count": 22, "metadata": { "ExecuteTime": { "end_time": "2020-10-06T20:09:52.718668Z", "start_time": "2020-10-06T20:09:52.712650Z" }, "id": "Mm52LU4gNP0u" }, "outputs": [], "source": [ "#örnek olarak şimdi DeepLearning paketi olan kerası kuruyorum\n", "#conda install keras" ] }, { "cell_type": "code", "execution_count": 23, "metadata": { "id": "uqqa5TaUNP0u", "outputId": "82aed378-8263-4823-deca-b747ea6da6e6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Package Version\n", "-------------------------------- ---------------------\n", "absl-py 1.4.0\n", "accelerate 0.34.2\n", "aiohappyeyeballs 2.4.0\n", "aiohttp 3.10.5\n", "aiosignal 1.3.1\n", "alabaster 0.7.16\n", "albucore 0.0.16\n", "albumentations 1.4.15\n", "ERROR: Pipe to stdout was broken\n", "Exception ignored in: <_io.TextIOWrapper name='' mode='w' encoding='utf-8'>\n", "BrokenPipeError: [Errno 32] Broken pipe\n" ] } ], "source": [ "#mevcut packageların listesi\n", "!pip list | head -n 10 #ilk 10u gelsin diye sınırladım(| ve sonrası Linux komutudur, windows için more veya less olması lazım)" ] }, { "cell_type": "code", "execution_count": 24, "metadata": { "id": "gmSg1OyhNP0u", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "045b5c23-be8a-4a76-cefd-6c1a5d1fbd44" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Name: keras\n", "Version: 3.4.1\n", "Summary: Multi-backend Keras.\n", "Home-page: https://github.com/keras-team/keras\n", "Author: Keras team\n", "Author-email: keras-users@googlegroups.com\n", "License: Apache License 2.0\n", "Location: /usr/local/lib/python3.10/dist-packages\n", "Requires: absl-py, h5py, ml-dtypes, namex, numpy, optree, packaging, rich\n", "Required-by: tensorflow\n" ] } ], "source": [ "#bi paket hakkında bilgi\n", "!pip show keras" ] }, { "cell_type": "code", "execution_count": 25, "metadata": { "id": "heyt5rURNP0v", "outputId": "e227d09b-f7b5-482c-9401-a3b311b2dd28", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (2.1.1)\n" ] } ], "source": [ "#eğer, daha üst sürümü varsa ona upgrade etmek için\n", "!pip install numpy --upgrade\n", "#veya conda update numpy" ] }, { "cell_type": "code", "execution_count": 26, "metadata": { "id": "RWA29wrHNP0v" }, "outputs": [], "source": [ "#yeni sürümle çalışıtırma sıkıntısı yaşarsanız eski sürüme dönebilirsiniz\n", "#!pip install --upgrade paketadı=versiyonno #(Ör:pip install --upgrade werkzeug==0.12.2)" ] }, { "cell_type": "code", "execution_count": 27, "metadata": { "id": "A4sLIE9JNP0v" }, "outputs": [], "source": [ "#paketi komple kaldırmak için\n", "#!pip uninstall paketadı" ] }, { "cell_type": "markdown", "metadata": { "id": "872p2Pk4NP0w" }, "source": [ "Bu komut, sadece paketi kaldırır, ama bi paket kurlurken birçok dependency ile kurlur, yani o paketin çalışması için gerekli olan başka paketler. Bunların bazılarını başka paketler de kullanıyor olabilir, bazılarını ise sadece bu kaldırmak istediğinzi paket kullanıyordur, işte bu son grup için de kaldırma işlemini tek tek yapmanız gerekir, ama neyseki bunun için da başka bir paket var, bunu kurup aşağıdaki gibi çalışıtırırsanız, kaldırmak istediğnzi paket ve onunla gelen gereksiz paketler de kaldırılır. şurada detaylı bilgi var." ] }, { "cell_type": "code", "execution_count": 28, "metadata": { "id": "g8U3N5-fNP0w", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "a2937875-8b25-492c-8427-8b8e57dcf6f1" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Requirement already satisfied: pip-autoremove in /usr/local/lib/python3.10/dist-packages (0.10.0)\n", "Requirement already satisfied: pip in /usr/local/lib/python3.10/dist-packages (from pip-autoremove) (24.1.2)\n", "Requirement already satisfied: setuptools in /usr/local/lib/python3.10/dist-packages (from pip-autoremove) (71.0.4)\n" ] } ], "source": [ "!pip install pip-autoremove" ] }, { "cell_type": "code", "execution_count": 29, "metadata": { "id": "sSz2VzLZNP0x", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "9e469c18-9fc5-4ddf-af1d-daa3f77dc70f" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "somepackage is not an installed pip module, skipping\n", "numpy 2.1.1 is installed but numpy<2.0a0,>=1.23 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<1.27,>=1.20 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2.0,>=1.18.5 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2,>=1 is required\n", "Redoing requirement with just package name...\n", "The 'jedi>=0.16' distribution was not found and is required by the application\n", "Skipping jedi\n", "numpy 2.1.1 is installed but numpy<2.1,>=1.22 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2,>=1.22.4; python_version < \"3.11\" is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2,>=1.17.0 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2.0a0,>=1.23 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2.0,>=1.17.3 is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2.0.0,>=1.23.5; python_version <= \"3.11\" is required\n", "Redoing requirement with just package name...\n", "numpy 2.1.1 is installed but numpy<2.0.0,>=1.19.0; python_version >= \"3.9\" is required\n", "Redoing requirement with just package name...\n", "The 'pycairo>=1.16.0' distribution was not found and is required by the application\n", "Skipping pycairo\n" ] } ], "source": [ "!pip-autoremove somepackage -y #remove \"somepackage\" plus its dependencies:" ] }, { "cell_type": "markdown", "metadata": { "id": "olXV9pE4NP0x" }, "source": [ "Bu arada bu dependencyler nedir görmek isterseniz, şu komutu çalıştırın." ] }, { "cell_type": "code", "execution_count": 30, "metadata": { "id": "BpjYWRBONP0x", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "04230509-114e-47ec-9e1f-8289404df40d" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "geopandas==1.0.1\n", "pandas==2.1.4\n", "pandas-datareader==0.10.0\n", "pandas-gbq==0.23.1\n", "pandas-stubs==2.1.4.231227\n", "sklearn-pandas==2.2.0\n" ] } ], "source": [ "!pip freeze | grep -i pandas" ] }, { "cell_type": "code", "execution_count": 31, "metadata": { "id": "hrDc8NU9NP0x", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "e90fbf40-748e-4bb5-947a-789cd9ddf3ae" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\u001b[31mERROR: Operation cancelled by user\u001b[0m\u001b[31m\n", "\u001b[0m^C\n" ] } ], "source": [ "#tüm outofdate paktleri görmek için, çok uzun sürebiliyor\n", "# !pip list --outdated" ] }, { "cell_type": "code", "execution_count": 32, "metadata": { "id": "0tTzGvk8NP0y", "outputId": "20491419-7038-42f4-f0b2-21bb4260fd93", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Python 3.10.12\n" ] } ], "source": [ "#python versiyonu öğrenmek\n", "!python --version" ] }, { "cell_type": "code", "execution_count": 33, "metadata": { "id": "s4FkMHDgNP0y" }, "outputs": [], "source": [ "#python'ın versiyonunu yükseltmek\n", "#!conda update python" ] }, { "cell_type": "code", "execution_count": 34, "metadata": { "id": "TbRMQRqQNP0y", "outputId": "ba1771d3-774c-449a-91e7-05bc6d639d09", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['/content',\n", " '/env/python',\n", " '/usr/lib/python310.zip',\n", " '/usr/lib/python3.10',\n", " '/usr/lib/python3.10/lib-dynload',\n", " '',\n", " '/usr/local/lib/python3.10/dist-packages',\n", " '/usr/lib/python3/dist-packages',\n", " '/usr/local/lib/python3.10/dist-packages/IPython/extensions',\n", " '/usr/local/lib/python3.10/dist-packages/setuptools/_vendor',\n", " '/root/.ipython']" ] }, "metadata": {}, "execution_count": 34 } ], "source": [ "#packageler hangi klasörlere kuruluyor\n", "import sys\n", "sys.path" ] }, { "cell_type": "code", "execution_count": 35, "metadata": { "id": "KKOwSxU_NP0y", "outputId": "dfd493d4-fba1-4ca9-ea56-2f754a3806c0", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['/usr/local/lib/python3.10/dist-packages', '/usr/lib/python3/dist-packages', '/usr/lib/python3.10/dist-packages']\n" ] } ], "source": [ "import site\n", "print(site.getsitepackages())" ] }, { "cell_type": "markdown", "metadata": { "id": "6tTwotkfNP0z" }, "source": [ "Özel kurulum şekillleri" ] }, { "cell_type": "markdown", "metadata": { "id": "LRuvt2JPNP0z" }, "source": [ "In IPython (jupyter) 7.3 and later, there is a magic %pip and %conda command that will install into the current kernel (rather than into the instance of Python that launched the notebook).\n", "\n", "%pip install geocoder\n", "\n", "! pip install --user (The ! tells the notebook to execute the cell as a shell command.)" ] }, { "cell_type": "markdown", "metadata": { "id": "1pmHX6_fNP0z" }, "source": [ "## Modül ve sınıflar(ve hatta fonksiyonları) kodumuza dahil etme" ] }, { "cell_type": "markdown", "metadata": { "id": "0GJH1mGGNP0z" }, "source": [ "* Modül referansı: import x, kullanımı: x'i takipeden üye şeklinde. x.falanmetod, x.falanproperty, x.falanfalan
\n", "* Modüldeki herşeyi dahil etme: from x import * , kullanımı: falanca(...)
\n", "* Tek birşeyi dahil etme: from x import falanca. falanca doğrudan kullanılabilir, x.falanca demeye gerek yok(üsstekinden farkı daha az şey importladık)" ] }, { "cell_type": "markdown", "metadata": { "id": "-mcfgHkjNP00" }, "source": [ "NOT: Performans açısından mümkün mertebe az şey import etmeye çalışın." ] }, { "cell_type": "code", "execution_count": 36, "metadata": { "id": "UaNmaSjUNP00", "outputId": "15302623-417b-4154-d641-a5eb03d55200", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "4.0" ] }, "metadata": {}, "execution_count": 36 } ], "source": [ "from math import sqrt #math modülünden sqrt fonksiyonu\n", "kök=sqrt(16)\n", "kök" ] }, { "cell_type": "code", "execution_count": 37, "metadata": { "scrolled": true, "id": "ks1w8Y0aNP00", "outputId": "4c87ae5b-ef1e-4f6c-94c7-06d82e97e2ed", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "drive sample_data\n" ] } ], "source": [ "from os import * # os modülündeki herşeyi\n", "mkdir(\"test\") #os dememize gerek yok. test diye bi klasör yarattık\n", "removedirs(\"test\") #hemen arkadan bu klasörü sildik\n", "!dir" ] }, { "cell_type": "markdown", "metadata": { "id": "okB1H3TMNP00" }, "source": [ "## Kendi modüllerinizi import etme" ] }, { "cell_type": "markdown", "metadata": { "id": "2dqwX3UoNP01" }, "source": [ "Zaman geçtiktçe, bazı işleri sık yaptığınızı farkedeceksiniz ve bunları(sınıflar, fonkisyonlar) kendinize ait bir modülde toplayacaksınız. Sonrasında bunu normal bir modül import eder gibi ederiz." ] }, { "cell_type": "code", "execution_count": 38, "metadata": { "id": "R5xgkco3NP01" }, "outputs": [], "source": [ "# mypythonutility.py isminde bir dosyanız olduğunuzu düşünrsek\n", "# import mypythonutility" ] }, { "cell_type": "markdown", "metadata": { "id": "aNJK8hsfNP01" }, "source": [ "Ancak bazen, kodlarımızda sık güncelleme yapmak durumunda kalabiliyoruz. o sırada da bu modülümü import ettiğimiz bir başka notebookta çalışırken güncel halini dikkate almasını isteriz. Bu işi, notebooku restart etmeden yapmanın bir yolu var:" ] }, { "cell_type": "code", "execution_count": 39, "metadata": { "ExecuteTime": { "end_time": "2020-07-07T08:46:49.796354Z", "start_time": "2020-07-07T08:46:49.732490Z" }, "id": "HtrnCd63NP01" }, "outputs": [], "source": [ "%load_ext autoreload\n", "%autoreload 2" ] }, { "cell_type": "markdown", "metadata": { "id": "bnsjjA8HNP01" }, "source": [ "## Kendi modülünüzü paket gibi kullanma" ] }, { "cell_type": "markdown", "metadata": { "id": "madB5No8NP02" }, "source": [ "Burayı daha ileride okuyun, şimdilik aklınızda bulunması için ve konu bütünlüğü adına burda olması daha iyi diye düşündüm. Yoksa bi üstteki maddeyi bilmeniz şimdilik yeterli." ] }, { "cell_type": "markdown", "metadata": { "id": "AhLgG4W7NP02" }, "source": [ "Yazdığınız modülü çağırmak istediğinizde ya onunla aynı klasörde olmanız ya da os.chdir() yaparak ilgili klasöre konumlanmanız gerekir. Sürekli bununla uğraşmamak için modülünüzü bir package haline getirmeniz faydalı olacaktır.\n", "\n", "Bunun için bir klasör yaratın ve içine bu py dosyanızı koyun. Bu klasöre bir de içi boş bir `'__init__.py'` dosyası koyun. Sonra bu klasörü tüm python paketlerinin olduğu klasöre(site-packages) taşıyın.\n", "\n", "Eğer ki jupyterhub gibi yetkilerinizin sınırlı olduğ bir ortamda çalışıyorsanız, ve site-packages'ta klasöre açma yetkiniz yoksa, kendinize ayrılmış alanda bu klasörü oluşturup sistem pathine ekleyin. Bunu da aşağıdaki komutla yapabilirsiniz." ] }, { "cell_type": "code", "execution_count": 40, "metadata": { "id": "DDXg5fiENP02" }, "outputs": [], "source": [ "# import sys\n", "# sys.path += \"klasörün konumu\"\n", "# print(sys.path) #path'e eklenmiş mi görmek için bunu da yazalım" ] }, { "cell_type": "markdown", "source": [ "colabde işler biraz daha fakrlı tabi, önce colab'e drive bağlanması için izin vermeniz gerekir. bunun için aşağıdaki hücre çalışıtırılrve izinler verilir" ], "metadata": { "id": "zDaFrPfMGbG1" } }, { "cell_type": "code", "source": [ "#Önce bu\n", "from google.colab import drive\n", "drive.mount(\"/content/drive/\")" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "zGNsNNXHGUzP", "outputId": "6f96224c-38e3-438f-fbfc-8d221f90daae" }, "execution_count": 41, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Drive already mounted at /content/drive/; to attempt to forcibly remount, call drive.mount(\"/content/drive/\", force_remount=True).\n" ] } ] }, { "cell_type": "code", "source": [ "#sonra da bu\n", "import sys\n", "sys.path.insert(0,'/content/drive/MyDrive/Programming/PythonRocks/') #mypyext isimli pkaet bu folderda" ], "metadata": { "id": "ZVMq4wsOGXk-" }, "execution_count": 42, "outputs": [] }, { "cell_type": "code", "source": [ "#artık kendi paketimi kullanabilirim\n", "import mypyext" ], "metadata": { "id": "V2S4SVZeGxBe" }, "execution_count": 43, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "h7KieE6uNP02" }, "source": [ "## Virtual Environment" ] }, { "cell_type": "markdown", "metadata": { "id": "YR5zjTzfNP02" }, "source": [ "https://realpython.com/python-virtual-environments-a-primer/ sayfasında güzel anlatılmış." ] }, { "cell_type": "code", "execution_count": 44, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:11:20.772078Z", "start_time": "2020-07-16T11:11:17.510325Z" }, "id": "r5o3HFN0NP02", "outputId": "70fe006c-5e78-4eb3-c3fa-bf532a57a8cd", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/bin/bash: line 1: py: command not found\n" ] } ], "source": [ "#En güncel pip'i kuralım\n", "!py -m pip install --upgrade pip" ] }, { "cell_type": "code", "execution_count": 45, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:11:54.505302Z", "start_time": "2020-07-16T11:11:45.665263Z" }, "id": "ASySAc96NP02", "outputId": "e52c8489-ab84-4f94-98c3-ed9a506a8faf", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/bin/bash: line 1: py: command not found\n" ] } ], "source": [ "#înstalling\n", "!py -m pip install --user virtualenv" ] }, { "cell_type": "code", "execution_count": 46, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:13:17.716666Z", "start_time": "2020-07-16T11:13:04.387067Z" }, "id": "r7yrAOiPNP03", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "edb55d1d-d4f6-489b-cf44-ec18d278433c" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/bin/bash: line 1: py: command not found\n" ] } ], "source": [ "#yaratma\n", "!py -m venv env #bulunduğumuz aktif klasör içinde yaratır" ] }, { "cell_type": "code", "execution_count": 47, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:20:21.083130Z", "start_time": "2020-07-16T11:20:20.978406Z" }, "id": "ZCKKAOIHNP03", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "5ad42391-a865-4aa9-eacc-980225767e12" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/bin/bash: line 1: .envScriptsactivate: command not found\n" ] } ], "source": [ "#aktivasyon\n", "!.\\env\\Scripts\\activate" ] }, { "cell_type": "code", "execution_count": 48, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:32:39.163270Z", "start_time": "2020-07-16T11:32:39.139368Z" }, "id": "Qr0NOscHNP03", "outputId": "687402a1-7c2e-4082-b9be-e86a9044ff0a", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[\"['/bin/bash: line 1: PATH: command not found']\"]" ] }, "metadata": {}, "execution_count": 48 } ], "source": [ "#bakalım PATH'e eklenmiş mi\n", "p=!PATH\n", "str(p).split(\";\")" ] }, { "cell_type": "code", "execution_count": 49, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:26:46.667387Z", "start_time": "2020-07-16T11:26:46.567600Z" }, "id": "tQRZEtUsNP03", "outputId": "43fa1970-61f0-4285-e422-ec782fdd2628", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/bin/bash: line 1: where: command not found\n" ] } ], "source": [ "!where python" ] }, { "cell_type": "code", "execution_count": 50, "metadata": { "ExecuteTime": { "end_time": "2020-07-16T11:34:58.198185Z", "start_time": "2020-07-16T11:34:58.120395Z" }, "id": "UIQA98IANP04", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "942c2e5e-338f-4ce2-e590-6cd9ec1c38cc" }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/bin/bash: line 1: deactivate: command not found\n" ] } ], "source": [ "!deactivate" ] }, { "cell_type": "markdown", "metadata": { "id": "GU0wvIngNP05" }, "source": [ "# Veri Tipleri" ] }, { "cell_type": "code", "execution_count": 51, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:25:19.504151Z", "start_time": "2021-05-15T15:25:19.499164Z" }, "id": "naqpUbfiNP06", "outputId": "02067706-ec4f-4f20-f8c1-dda57a202102", "colab": { "base_uri": "https://localhost:8080/", "height": 89 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'\\nmerhaba\\nBu 3 tırnak ifadesi fonksiyonların docstringi amaçlı kullanılır\\nAnkca çok satıra yayılan yorumlar için de kullanılabilir\\n'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 51 }, { "output_type": "stream", "name": "stdout", "text": [ "\n", "\n", "\n" ] } ], "source": [ "i=1\n", "f=1.0\n", "s=\"merhaba\"\n", "#bu bir yorum\n", "\"\"\"\n", "merhaba\n", "Bu 3 tırnak ifadesi fonksiyonların docstringi amaçlı kullanılır\n", "Ankca çok satıra yayılan yorumlar için de kullanılabilir\n", "\"\"\"\n", "print(type(i))\n", "print(type(f))\n", "print(type(s))" ] }, { "cell_type": "code", "execution_count": 52, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:25:35.993553Z", "start_time": "2021-05-15T15:25:35.988568Z" }, "id": "EzMolcdhNP06" }, "outputs": [], "source": [ "#Legal variable names:\n", "myvar = \"John\"\n", "my_var = \"John\"\n", "_my_var = \"John\"\n", "myVar = \"John\"\n", "MYVAR = \"John\"\n", "myvar2 = \"John\"" ] }, { "cell_type": "code", "execution_count": 53, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:25:38.825715Z", "start_time": "2021-05-15T15:25:38.822723Z" }, "id": "lZLcQX6GNP07" }, "outputs": [], "source": [ "#Illegal variable names:\n", "# 2myvar = \"John\"\n", "# my-var = \"John\"\n", "# my var = \"John\"" ] }, { "cell_type": "code", "execution_count": 54, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:25:39.549119Z", "start_time": "2021-05-15T15:25:39.545090Z" }, "id": "HBFwPMj-NP07", "outputId": "60b8697e-7f96-49fb-b9c4-d12820db9522", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Orange\n", "Banana\n", "Cherry\n" ] } ], "source": [ "#çoklu değer atama\n", "x, y, z = \"Orange\", \"Banana\", \"Cherry\"\n", "print(x)\n", "print(y)\n", "print(z)" ] }, { "cell_type": "code", "execution_count": 55, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:25:42.188664Z", "start_time": "2021-05-15T15:25:42.184639Z" }, "id": "MJi7krowNP07", "outputId": "aa3dfb6f-ef05-49c9-b6e8-74a9d3102296", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "1000000000.0" ] }, "metadata": {}, "execution_count": 55 }, { "output_type": "execute_result", "data": { "text/plain": [ "123000000000.0" ] }, "metadata": {}, "execution_count": 55 } ], "source": [ "#exponential\n", "x = 1e9\n", "y = 123E9\n", "x\n", "y" ] }, { "cell_type": "markdown", "metadata": { "id": "aXlnpOTXNP07" }, "source": [ "## Veri tipi dönüştürme" ] }, { "cell_type": "code", "execution_count": 56, "metadata": { "ExecuteTime": { "end_time": "2020-11-23T07:25:00.681052Z", "start_time": "2020-11-23T07:25:00.672077Z" }, "id": "E_LZ52ObNP08", "outputId": "985d4982-3237-42c3-b00e-d8185614d42f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "(1.0, float)" ] }, "metadata": {}, "execution_count": 56 }, { "output_type": "execute_result", "data": { "text/plain": [ "(2, int)" ] }, "metadata": {}, "execution_count": 56 }, { "output_type": "execute_result", "data": { "text/plain": [ "('1.0', str)" ] }, "metadata": {}, "execution_count": 56 }, { "output_type": "stream", "name": "stdout", "text": [ "1.0 \n" ] } ], "source": [ "y=float(1)\n", "z=int(2.8)\n", "s=str(y)\n", "\n", "y,type(y)\n", "z,type(z)\n", "s,type(s)\n", "print(s,type(s))" ] }, { "cell_type": "code", "execution_count": 57, "metadata": { "ExecuteTime": { "end_time": "2020-11-23T07:26:26.792404Z", "start_time": "2020-11-23T07:26:26.788377Z" }, "id": "d29OHFN5NP08", "outputId": "3186d6a9-9def-4286-d7d8-e63a6f1ebf0b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "int" ] }, "metadata": {}, "execution_count": 57 } ], "source": [ "z=\"1\"\n", "y=int(z)\n", "type(y)" ] }, { "cell_type": "code", "execution_count": 58, "metadata": { "ExecuteTime": { "end_time": "2020-11-23T07:26:41.582918Z", "start_time": "2020-11-23T07:26:41.577930Z" }, "id": "PiMmMGVJNP08", "outputId": "34dc0e74-8792-490a-e13d-d2ce3c953573", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "True\n" ] } ], "source": [ "x=1\n", "print(isinstance(x,int))" ] }, { "cell_type": "markdown", "metadata": { "id": "wL53qi48NP08" }, "source": [ "# Fonksiyonlar" ] }, { "cell_type": "markdown", "metadata": { "id": "FjXVoYagNP09" }, "source": [ "## Klasik fonksiyon" ] }, { "cell_type": "markdown", "metadata": { "id": "KFq885x5NP09" }, "source": [ "Genel olarak fonksiyonların ne olduğunu başka bir dokümandan öğrenmiş olmanız beklenimektedir. Başta da belirttiğim gibi bu dokümanın amacı büyük bir cheatsheet sağlamak." ] }, { "cell_type": "code", "execution_count": 59, "metadata": { "id": "VFsn7nMeNP09", "outputId": "0b9a6e68-5e5a-4d81-aa9d-7f0d024a3c6b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "selam\n" ] } ], "source": [ "def islem_yapan_parametresiz_fonksiyon(): #c tabanlı dillerdeki void dönüş tipi\n", " print(\"selam\")\n", "\n", "islem_yapan_parametresiz_fonksiyon()" ] }, { "cell_type": "code", "execution_count": 60, "metadata": { "ExecuteTime": { "end_time": "2020-11-21T17:03:37.328846Z", "start_time": "2020-11-21T17:03:37.324822Z" }, "id": "w0pvtc7YNP09", "outputId": "071a1d2f-43b4-4113-cd7e-43304454242f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "16\n" ] } ], "source": [ "def sonuc_donduren_ve_parametre_almis_fonksiyon(karesi_alinacak_sayi):\n", " \"\"\"\n", " bu fonksiyon kendisine gelen sayının karesini döndürür\n", " Args:\n", " karesi_alinacak_sayi: sayı\n", " \"\"\"\n", " return karesi_alinacak_sayi**2\n", "\n", "sonuc=sonuc_donduren_ve_parametre_almis_fonksiyon(4) #dönen sonucu bi dğeişkene atıyorum\n", "print(sonuc)" ] }, { "cell_type": "code", "execution_count": 61, "metadata": { "id": "bAwhbhJNNP09", "outputId": "ac420b3c-4347-40ce-88b7-04b69fb73b74", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "50\n", "5\n" ] } ], "source": [ "#pythonda fonksiyonlar bazı dillerdeki durumun aksine çok değer döndürülebilir.\n", "def cokdegerdondur(sayı):\n", " return sayı,sayı*10,sayı*100\n", "\n", "kendi,onkat,yuzkat=cokdegerdondur(5)\n", "print(onkat)\n", "print(kendi)" ] }, { "cell_type": "markdown", "metadata": { "id": "45R5XYhVNP0-" }, "source": [ "## Paramarray ile esnek sayıda parametre kullanımı ve default değer kavramı" ] }, { "cell_type": "markdown", "metadata": { "id": "iVx5DrgbNP0-" }, "source": [ "Parametreler belirlenmiş sayıda olmak zorunda değil. Esnek sayıda parametre alma imkanı var." ] }, { "cell_type": "code", "execution_count": 62, "metadata": { "ExecuteTime": { "end_time": "2020-11-21T17:03:09.037233Z", "start_time": "2020-11-21T17:03:09.015293Z" }, "id": "ggvC9iCnNP0-", "outputId": "53ddd144-1479-4360-e5ed-a9b7f72c6e48", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "5.5\n", "5.5\n" ] } ], "source": [ "def SayılarıToplaXeBöl(arg1,*args): #arg1 olmak zorunda değil, ama olacaksa paramarrayden önce olmalı\n", " \"\"\"\n", " Bu fonksiyon ilk parametreden sonrakileri toplayıp ilk parametreye böler\n", " \"\"\"\n", " Toplam=0\n", " for a in args:\n", " Toplam+=a\n", " return Toplam/arg1\n", "\n", "x=SayılarıToplaXeBöl(10,1,2,3,4,5,6,7,8,9,10) #parametreler hardcoded yazıldıysa \"*\" yazmıyoruz.\n", "print(x)\n", "y=SayılarıToplaXeBöl(10,*range(1,11)) #parametreler bir fonksiyon ile dönüyorsa veya bir değişkense \"*\" var\n", "print(y)" ] }, { "cell_type": "code", "execution_count": 63, "metadata": { "id": "QCVh9P3VNP0-", "outputId": "44159cc0-ebd6-4b7e-f4ff-70f7f8e333e2", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "ad Volkan\n", "soyad Yurtseven\n", "ad Volkan\n", "soyad Yurtseven\n" ] } ], "source": [ "def dictparametreli(**kwargs): #** olursa parametre olarak dictionary veya daha genel olarak keyworded arguments alır\n", " for k,v in kwargs.items():\n", " print(k,v)\n", "\n", "dict_={}\n", "dict_[\"ad\"]=\"Volkan\"\n", "dict_[\"soyad\"]=\"Yurtseven\"\n", "dictparametreli(**dict_) #değişken şeklinde olduğu için ** ile\n", "#veya\n", "dictparametreli(ad=\"Volkan\",soyad=\"Yurtseven\")" ] }, { "cell_type": "markdown", "metadata": { "id": "qhqxgPqnNP0_" }, "source": [ "Bazı parametreler default değerleriyle yazılırlar. Fonksiyona ilgili değer geçirilimezse bu default değer kullanılır" ] }, { "cell_type": "code", "execution_count": 64, "metadata": { "id": "a11oPHXQNP0_", "outputId": "25d44ff0-24fd-4e25-c56c-90d04ebd377f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "100 5 10\n" ] } ], "source": [ "def opsiyonelli(adet,min_=1, max_=10):\n", " print(adet,min_,max_)\n", "\n", "opsiyonelli(100,5) #son parametre 10 geçer" ] }, { "cell_type": "markdown", "metadata": { "id": "hpsrLM2NNP0_" }, "source": [ "## Lambda ve anonymous function" ] }, { "cell_type": "markdown", "metadata": { "id": "Oh8NTAtQNP0_" }, "source": [ "Lambda ifadeler, fonksiyon tanımlamak yerine inline şekilde işlem yapmaya imkan verir" ] }, { "cell_type": "code", "execution_count": 65, "metadata": { "id": "9brn9m6tNP0_", "outputId": "77899572-821d-4de2-d8d8-38b6afa5ab72", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "100\n", "100\n" ] } ], "source": [ "def kareal(sayı):\n", " return sayı**2\n", "\n", "#yukarıdaki fonksiyonu tanımlamak yerine lambda yazabilriz\n", "kareal2=lambda x:x**2\n", "\n", "print(kareal(10))\n", "print(kareal2(10))" ] }, { "cell_type": "markdown", "metadata": { "id": "z0FTYzdfNP1A" }, "source": [ "# Stringler" ] }, { "cell_type": "markdown", "metadata": { "id": "2IGiLuDJNP1A" }, "source": [ "## Slicing" ] }, { "cell_type": "code", "source": [], "metadata": { "id": "mwb4VAMlGLmO" }, "execution_count": 65, "outputs": [] }, { "cell_type": "code", "execution_count": 66, "metadata": { "id": "fgPi68hyNP1A" }, "outputs": [], "source": [ "from mypyext.pythonutility import * #kendi yazdığım utility modülünü import ediyorum.\n", "#burada farklı print şekilleri var. print ederken satır numarsını da yazdıran printy gibi.\n", "#View menüsünden Toggle Line Numbers yapmış olmanız lazım." ] }, { "cell_type": "code", "execution_count": 67, "metadata": { "id": "O9FdQke2NP1A", "outputId": "0e50ad19-2dc7-44e0-868b-26450dea0b9f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "(2, ['printy(metin[0])\\n']) \n", "----------\n", "v\n", " \n", "(3, ['printy(metin[:3]) #left 3\\n']) \n", "----------\n", "vol\n", " \n", "(4, ['printy(metin[4:]) #substr\\n']) \n", "----------\n", "an yurtseven\n", " \n", "(5, ['printy(metin[2:5]) #substr\\n']) \n", "----------\n", "lka\n", " \n", "(6, ['printy(metin[-1]) #son\\n']) \n", "----------\n", "n\n", " \n", "(7, ['printy(metin[-3:]) #right 3\\n']) \n", "----------\n", "ven\n", " \n", "(8, ['printy(metin[::-1]) #ters\\n']) \n", "----------\n", "nevestruy naklov\n", " \n" ] } ], "source": [ "metin=\"volkan yurtseven\"\n", "printy(metin[0])\n", "printy(metin[:3]) #left 3\n", "printy(metin[4:]) #substr\n", "printy(metin[2:5]) #substr\n", "printy(metin[-1]) #son\n", "printy(metin[-3:]) #right 3\n", "printy(metin[::-1]) #ters" ] }, { "cell_type": "markdown", "metadata": { "id": "pLFNMOsqNP1A" }, "source": [ "## String formatlama" ] }, { "cell_type": "code", "execution_count": 68, "metadata": { "id": "mI86HBbSNP1B", "outputId": "a8810db4-ad6b-4696-d72c-7ec7b255fee0", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'İnsanların yaklaşık yarısı kadın olup kalanı erkektir'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 68 } ], "source": [ "mesaj=\"İnsanların yaklaşık %s kadın olup %s erkektir\" % (\"yarısı\",\"kalanı\")\n", "mesaj\n", "#s:string, d:sayı" ] }, { "cell_type": "code", "execution_count": 69, "metadata": { "id": "mqxUUWDsNP1B", "outputId": "c02d5403-8e73-4820-83b3-d4483de67308", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'Python güzel bir dildir'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 69 } ], "source": [ "#daha çok bu yöntem, {}\n", "mesaj=\"Python {} bir dildir\".format(\"güzel\")\n", "mesaj" ] }, { "cell_type": "code", "execution_count": 70, "metadata": { "id": "dNuqh78-NP1B", "outputId": "6ddcdb5b-9140-42d2-8c86-de32607c33f2", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'python güzel bir dildir'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 70 } ], "source": [ "# ya da + ile basit concat\n", "mesaj=\"python\"\n", "mesaj=mesaj + \" güzel bir dildir\"\n", "mesaj" ] }, { "cell_type": "code", "execution_count": 71, "metadata": { "ExecuteTime": { "end_time": "2020-11-21T17:05:12.848696Z", "start_time": "2020-11-21T17:05:12.843709Z" }, "id": "E_PnUV8MNP1B", "outputId": "4dd41758-c611-46a3-a539-07cb28557f97", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Benim adım volkan olup yaşım 41\n" ] } ], "source": [ "#en son yöntem: f-string / f-literal olarak da geçer\n", "ad=\"volkan\"\n", "yas=41\n", "print(f\"Benim adım {ad} olup yaşım {yas}\")" ] }, { "cell_type": "code", "execution_count": 72, "metadata": { "id": "0JMEH0lQNP1B", "outputId": "c5d8f596-e9f4-44f9-8048-d8b505545b2e", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "pi sayısı yaklaşık olarak 3.14 olup dünyada yaklaşık 8,000,000,000 kişi yaşamaktadır\n" ] } ], "source": [ "#f ilteral ile binlik ayraç ve küsurat işleri\n", "dunyanufusu=8000000000\n", "pi=3.14159\n", "print(f\"pi sayısı yaklaşık olarak {pi:.2f} olup dünyada yaklaşık {dunyanufusu:,} kişi yaşamaktadır\")" ] }, { "cell_type": "markdown", "metadata": { "id": "qf6LA4sjNP1B" }, "source": [ "## metinsel fonksiyonlar" ] }, { "cell_type": "code", "execution_count": 73, "metadata": { "id": "_M9CGD7qNP1C", "outputId": "bbe4728c-26cc-40fd-d3c3-01dd3fb53630", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['volkan', 'yurtseven']" ] }, "metadata": {}, "execution_count": 73 } ], "source": [ "parçalı=metin.split()\n", "parçalı" ] }, { "cell_type": "code", "execution_count": 74, "metadata": { "id": "dnEvfAL2NP1D", "outputId": "a9713ac0-e508-415c-b8f4-5f209069d62d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "volkan yurtsevenvolkan yurtsevenvolkan yurtseven\n" ] } ], "source": [ "print(metin*3)" ] }, { "cell_type": "code", "execution_count": 75, "metadata": { "id": "MvXaA9DINP1D", "outputId": "e6de7903-0628-4aed-b9e7-8c490e6af669", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'volkan yurtsivin'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 75 } ], "source": [ "metin.replace(\"e\",\"i\")" ] }, { "cell_type": "code", "execution_count": 76, "metadata": { "id": "DNDoJ0JNNP1D", "outputId": "85032865-c373-475a-967b-a22489ee2ebc", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "VOLKAN YURTSEVEN volkan yurtseven Volkan yurtseven Volkan Yurtseven\n" ] } ], "source": [ "print(metin.upper(), metin.lower(), metin.capitalize(), metin.title())" ] }, { "cell_type": "code", "execution_count": 77, "metadata": { "id": "YbKcPR6ANP1D", "outputId": "eea277cf-e0f7-4423-8731-da242e989cc0", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "True False\n" ] } ], "source": [ "print(metin.startswith(\"v\"),metin.endswith(\"d\"))" ] }, { "cell_type": "code", "execution_count": 78, "metadata": { "id": "Y5UV3hBTNP1D", "outputId": "6d3ccbc1-690f-4a34-df7d-7db95a11869e", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "yeni:naber dostum.\n" ] } ], "source": [ "kelime=\" naber dostum \"\n", "print(\"yeni:\"+kelime.strip()+\".\") #ortadakini silmez" ] }, { "cell_type": "code", "execution_count": 79, "metadata": { "id": "V30U1mtGNP1D", "outputId": "251c210a-f3dc-428f-fdff-126583c603fb", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "True True True False\n", "True False False False\n", "False False True False\n", "True True True True\n" ] } ], "source": [ "isim=\"Volkan\"\n", "user=\"ABC123\"\n", "yas=\"42\" #tırnak içinde olmalı\n", "mail=\"volkan.yurtseven@hotmail.com\"\n", "\n", "print(isim.isalnum(),user.isalnum(),yas.isalnum(),mail.isalnum())\n", "print(isim.isalpha(),user.isalpha(),yas.isalpha(),mail.isalpha())\n", "print(isim.isdigit(),user.isdigit(),yas.isdigit(),mail.isdigit()) #isnumeric de olur. fark için https://stackoverflow.com/questions/44891070/whats-the-difference-between-str-isdigit-isnumeric-and-isdecimal-in-python\n", "print(isim.isprintable(),user.isprintable(),yas.isprintable(),mail.isprintable())" ] }, { "cell_type": "markdown", "metadata": { "id": "2PHUf6e9NP1D" }, "source": [ "Tüm diğer string metodları için şuraya bakabilirsiniz: https://www.w3schools.com/python/python_ref_string.asp" ] }, { "cell_type": "markdown", "metadata": { "id": "JeHAxJp_NP1D" }, "source": [ "## özel karekterler ve literaller" ] }, { "cell_type": "code", "execution_count": 80, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:14:48.704386Z", "start_time": "2021-05-15T15:14:48.698402Z" }, "id": "H79D3lBENP1E", "outputId": "8b9deac7-603a-4852-b5b8-2b88edfab22c", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Şifre:\"abc123\"\n", "c:\\python\\abc\\xyz\\sdf\n", "c:\\python\\abc\\xyz\\sdf\n" ] } ], "source": [ "#escape\n", "print(\"Şifre:\\\"abc123\\\"\")\n", "print(\"c:\\\\python\\\\abc\\\\xyz\\\\sdf\")\n", "print(r\"c:\\python\\abc\\xyz\\sdf\") #r:raw, escape char'ı görmezden gel demek" ] }, { "cell_type": "markdown", "metadata": { "id": "NAozOYcFNP1E" }, "source": [ "![resim.png]()" ] }, { "cell_type": "code", "execution_count": 81, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:15:28.241971Z", "start_time": "2021-05-15T15:15:28.237943Z" }, "id": "-i7-rY96NP1E", "outputId": "7aa91e98-74a2-4c44-9628-1b006fb71141", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n", "\n" ] } ], "source": [ "#literaller: b,r,f\n", "a=b\"volkan\"\n", "b=\"volkan\"\n", "print(type(a))\n", "print(type(b))" ] }, { "cell_type": "code", "execution_count": 82, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:15:36.168794Z", "start_time": "2021-05-15T15:15:36.163806Z" }, "id": "J2Fz9zf4NP1F", "outputId": "31bfebe2-979b-4661-c88f-4a9a224f7647", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "39" ] }, "metadata": {}, "execution_count": 82 }, { "output_type": "execute_result", "data": { "text/plain": [ "55" ] }, "metadata": {}, "execution_count": 82 } ], "source": [ "import sys\n", "sys.getsizeof(a)\n", "sys.getsizeof(b)" ] }, { "cell_type": "code", "execution_count": 83, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:17:16.459938Z", "start_time": "2021-05-15T15:17:16.455911Z" }, "id": "A6FqM3guNP1F", "outputId": "ecf9afd1-e922-4d00-e5ac-1d9efcffd778", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "True" ] }, "metadata": {}, "execution_count": 83 } ], "source": [ "adres1=\"c:\\\\falanca\\\\filanca\"\n", "adres2=r\"c:\\falanca\\filanca\"\n", "adres1==adres2" ] }, { "cell_type": "markdown", "metadata": { "id": "rZFts1OyNP1F" }, "source": [ "## diğer işlemler" ] }, { "cell_type": "code", "execution_count": 84, "metadata": { "id": "9FtcLg35NP1F", "outputId": "70a43165-68d9-47ed-bcac-427422201cfc", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['v', 'o', 'l', 'k', 'a', 'n', ' ', 'y', 'u', 'r', 't', 's', 'e', 'v', 'e', 'n']\n" ] } ], "source": [ "#liste çevirme\n", "liste=list(metin)\n", "print(liste)" ] }, { "cell_type": "code", "execution_count": 85, "metadata": { "id": "DfD4cy0BNP1G", "outputId": "70708cf6-e380-41f0-d012-cf83afa80708", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "True\n", "-1\n", "bulamadı\n" ] } ], "source": [ "#içinde var mı kontrolü\n", "print(\"l\" in metin)\n", "print(metin.find(\"z\")) #bulamazsa -1\n", "try:\n", " print(metin.index(\"z\")) #bulamazsa hata alır\n", "except:\n", " print(\"bulamadı\")" ] }, { "cell_type": "code", "execution_count": 86, "metadata": { "id": "n9BcQcjXNP1G", "outputId": "f5d2f00d-35d7-44a4-9940-ef77a0c81039", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "v\n", "o\n", "l\n", "k\n", "a\n", "n\n", " \n", "y\n", "u\n", "r\n", "t\n", "s\n", "e\n", "v\n", "e\n", "n\n" ] } ], "source": [ "for m in metin:\n", " print(m,end=\"\\n\")" ] }, { "cell_type": "code", "execution_count": 87, "metadata": { "id": "66Wn-besNP1G" }, "outputs": [], "source": [ "#aralarda boşluk falan varsa \"r\" başta olacak şekilde kullanırız. c#'taki @ gibi\n", "path=r\"E:\\falan filan klasörü\\sub klasör\"" ] }, { "cell_type": "code", "execution_count": 88, "metadata": { "id": "hs_mPp5pNP1G", "outputId": "d1021801-1c58-4aad-8894-fce92e82168f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "2" ] }, "metadata": {}, "execution_count": 88 } ], "source": [ "metin.count(\"e\") #metin değişkeninde e harfi kaç kez geçiyor" ] }, { "cell_type": "markdown", "metadata": { "id": "Vty7-uAxNP1I" }, "source": [ "## string modülü" ] }, { "cell_type": "code", "execution_count": 89, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:32:18.288235Z", "start_time": "2021-05-15T15:32:18.284245Z" }, "id": "YBv1iAbcNP1I" }, "outputs": [], "source": [ "import string" ] }, { "cell_type": "code", "execution_count": 90, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:33:28.223886Z", "start_time": "2021-05-15T15:33:28.213888Z" }, "id": "EP_ozwnPNP1I", "outputId": "98c31afe-43ca-40c0-e5b7-8b5d05a1a8ac", "colab": { "base_uri": "https://localhost:8080/", "height": 108 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'!\"#$%&\\'()*+,-./:;<=>?@[\\\\]^_`{|}~'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 90 }, { "output_type": "execute_result", "data": { "text/plain": [ "'0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!\"#$%&\\'()*+,-./:;<=>?@[\\\\]^_`{|}~ \\t\\n\\r\\x0b\\x0c'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 90 }, { "output_type": "execute_result", "data": { "text/plain": [ "' \\t\\n\\r\\x0b\\x0c'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 90 }, { "output_type": "execute_result", "data": { "text/plain": [ "'0123456789'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 90 }, { "output_type": "execute_result", "data": { "text/plain": [ "'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 90 } ], "source": [ "string.punctuation\n", "string.printable\n", "string.whitespace\n", "string.digits\n", "string.ascii_letters" ] }, { "cell_type": "markdown", "metadata": { "id": "qG9v0uzDNP1I" }, "source": [ "# Koşullu yapılar" ] }, { "cell_type": "markdown", "metadata": { "id": "ARz6Uo5sNP1I" }, "source": [ "Koşullu yapılar, döngüler ve veri yapıları tüm programalama dillerinin ortak özellikleri olup iyi kavranması gerekirler. Bu konuda kendinizi test edeceğiniz güzel bir site var. Burada çeştli konularda kolaydan zora kadar farklı seviyelerde sorular var, bunları çözüp gönderiyorsunuz, puan kazanıyorsunuz. bu siteyi kullanmanızı tavsiye ederim.\n", "\n", "https://www.hackerrank.com" ] }, { "cell_type": "code", "execution_count": 91, "metadata": { "id": "FefBC14HNP1I", "outputId": "45b5fea9-ae3d-4347-8487-ae56e6b4a468", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "20den küçük\n" ] } ], "source": [ "i=10 #bunu sırasıyla 10,20 ve 30 yapark çalışıtırın\n", "if i<20:\n", " print(\"20den küçük\")\n", "elif i==20: #çift =\n", " print(\"tam 20\")\n", "else:\n", " print(\"20den büyük\")" ] }, { "cell_type": "code", "execution_count": 92, "metadata": { "id": "7C5VTOawNP1I", "outputId": "bf7c6a4b-549e-4920-b08e-062cbabf2fa6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "low\n" ] } ], "source": [ "#one-liner -(ternary) if-else\n", "x=3\n", "sonuc=\"high\" if x>10 else \"low\"\n", "print(sonuc)" ] }, { "cell_type": "markdown", "metadata": { "id": "mpsWNlVDNP1J" }, "source": [ "# Döngüler" ] }, { "cell_type": "markdown", "metadata": { "id": "cqV15EutNP1J" }, "source": [ "Genelde list, dict gibi veri yapıları içinde dolaşmaya yararlar. Bu veri yapılarını az aşağıda detaylı göreceğiz\n", "\n", "iki tür döngü yapımız var. while ve for.
\n", "for, foreach şeklindedir, klasik for yok. onun yerine range fonksiyonundan yararlanılabilir." ] }, { "cell_type": "code", "execution_count": 93, "metadata": { "id": "ezJYB-fpNP1J", "outputId": "9e6e1330-9603-47f3-ada5-2b839b488a93", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "apple\n", "banana\n", "cherry\n" ] } ], "source": [ "fruits = [\"apple\", \"banana\", \"cherry\"]\n", "for x in fruits:\n", " print(x)" ] }, { "cell_type": "code", "execution_count": 94, "metadata": { "id": "Y6BS_0tBNP1J", "outputId": "5084f3d4-552b-4da5-c35a-389bdbb3ec84", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "apple\n", "banana\n", "cherry\n" ] } ], "source": [ "#klasik for için range kullanımı.\n", "for i in range(len(fruits)):\n", " print(fruits[i])" ] }, { "cell_type": "code", "execution_count": 95, "metadata": { "id": "lrVY0sbPNP1J", "outputId": "098a446c-a9b8-4aef-8992-f09764a96aa3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "v-o-l-k-a-n-" ] } ], "source": [ "#metinler de loop ile dolaşılabilir\n", "isim=\"volkan\"\n", "for i in isim:\n", " print(i,end=\"-\")" ] }, { "cell_type": "code", "execution_count": 96, "metadata": { "scrolled": true, "id": "wi7ZbMWRNP1K", "outputId": "c4fa016f-2d84-4e73-d2b7-d724cd94a1b3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "apple\n", "banana\n" ] } ], "source": [ "#döngüden çıkış\n", "fruits = [\"apple\", \"banana\", \"cherry\"]\n", "for x in fruits:\n", " print(x)\n", " if x == \"banana\":\n", " break" ] }, { "cell_type": "code", "execution_count": 97, "metadata": { "id": "duYtOUPmNP1K", "outputId": "4aa20531-981f-46c2-e0bd-00e8fae18e52", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "1\n", "2\n", "3\n", "4\n", "5\n" ] } ], "source": [ "#while ile bir şart gerçekleş(me)tiği sürece döngüde kalırız\n", "i = 1\n", "while i < 6:\n", " print(i)\n", " i += 1" ] }, { "cell_type": "code", "execution_count": 98, "metadata": { "scrolled": true, "id": "eQCKgDWBNP1K", "outputId": "bda3c61c-0e5a-4508-af7e-db42ab154e8b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "1\n", "2\n", "3\n" ] } ], "source": [ "#belirli bir ara şart gerçekleşirse döngüden çıkabiliriz\n", "i = 1\n", "while i < 6:\n", " print(i)\n", " if i == 3:\n", " break\n", " i += 1" ] }, { "cell_type": "code", "execution_count": 99, "metadata": { "id": "NiAEG1r2NP1K", "outputId": "cfbf00d3-4cd9-4bd8-b464-fa833ced013d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Karesi alınacak bir sayı giriniz, çıkış için q tuşuna basın:5\n", "25\n", "Karesi alınacak bir sayı giriniz, çıkış için q tuşuna basın:q\n", "Hoşçakalın\n" ] } ], "source": [ "#while'ın en sık kullanımlarından biri, kullanıcıdan exit/quit yazana kadar hep girdi almak\n", "while True:\n", " rakam=input(\"Karesi alınacak bir sayı giriniz, çıkış için q tuşuna basın:\")\n", " if rakam==\"q\":\n", " print(\"Hoşçakalın\")\n", " break\n", " else:\n", " print(str(int(rakam)**2))" ] }, { "cell_type": "code", "execution_count": 100, "metadata": { "id": "2q8p5EGKNP1M", "outputId": "72421a0e-219d-4a2e-befe-6e6e7299d228", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ " #\n", " ##\n", " ###\n", " ####\n", " #####\n", "######\n" ] } ], "source": [ "#hackerrank sitesindeki bir ödev\n", "def staircase(n):\n", " for i in range(n):\n", " print((n-i-1)*\" \"+\"#\"*(i+1))\n", "staircase(6)" ] }, { "cell_type": "markdown", "metadata": { "id": "thKPyBMYNP1M" }, "source": [ "## Döngü içinde \"else\" kullanımı" ] }, { "cell_type": "markdown", "metadata": { "id": "yhSKM3FZNP1M" }, "source": [ "### for döngülerinde" ] }, { "cell_type": "markdown", "metadata": { "id": "j5R8PGCcNP1M" }, "source": [ "tüm liste bittiğinde son olarak bu kısım yürütülür" ] }, { "cell_type": "code", "execution_count": 101, "metadata": { "scrolled": true, "id": "pqzWbd1dNP1M", "outputId": "6805cdf4-f681-4b0b-ba97-e61d2427aabc", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "0\n", "1\n", "2\n", "3\n", "bitti\n" ] } ], "source": [ "for i in range(4):\n", " print(i)\n", "else:\n", " print(\"bitti\")" ] }, { "cell_type": "code", "execution_count": 102, "metadata": { "id": "vU1wyjcWNP1M", "outputId": "2067ad18-08a8-431d-bb14-e1d6a59e773a", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "10 equals 2*5.0\n", "11 bir asal sayıdır\n", "12 equals 2*6.0\n", "13 bir asal sayıdır\n", "14 equals 2*7.0\n", "15 equals 3*5.0\n", "16 equals 2*8.0\n", "17 bir asal sayıdır\n", "18 equals 2*9.0\n", "19 bir asal sayıdır\n" ] } ], "source": [ "for num in range(10,20):\n", " for i in range(2,num):\n", " if num%i==0:\n", " j=num/i\n", " print(\"{} equals {}*{}\".format(num,i,j))\n", " break\n", " else:\n", " print(num,\" bir asal sayıdır\")" ] }, { "cell_type": "markdown", "metadata": { "id": "DHG9LJg6NP1M" }, "source": [ "### while döngülerinde" ] }, { "cell_type": "markdown", "metadata": { "id": "7MvPwcywNP1M" }, "source": [ "koşul sağlanmadığında yürütülür" ] }, { "cell_type": "code", "execution_count": 103, "metadata": { "id": "8Ue-TWCGNP1N", "outputId": "fcb8535b-6fc5-4c86-eb3c-72c024687600", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "5\n", "4\n", "3\n", "2\n", "1\n", "artık sağlanmıyor\n" ] } ], "source": [ "n=5\n", "while n!=0:\n", " print(n)\n", " n-=1\n", "else:\n", " print(\"artık sağlanmıyor\")" ] }, { "cell_type": "markdown", "metadata": { "id": "FWBgR1YXNP1O" }, "source": [ "## içiçe döngülerden çıkış" ] }, { "cell_type": "markdown", "metadata": { "id": "ESmXvmWeNP1O" }, "source": [ "içiçe döngü varsa, break ifadesi en içteki döngüden çıkar ve o bloktan sonraki ilk satırdan devam eder" ] }, { "cell_type": "markdown", "metadata": { "id": "qbdFuaC8NP1O" }, "source": [ "### iç döngüden çıkış, dış döngüye devam" ] }, { "cell_type": "code", "execution_count": 104, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T20:42:53.102424Z", "start_time": "2020-11-22T20:42:53.093449Z" }, "id": "xNf-LiZoNP1O", "outputId": "30b19ac0-f428-4393-dcd4-2f9f44c045fb", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "b ali\n", "b dursun\n", "b ıtır\n", "b emel\n", "b cemil\n", "b için iç döngüde eşleşme bulunamadı\n", "\n", "a ali\n", "ali ekleniyor ve iç döngüden çıkış yapılacak\n", "\n", "c ali\n", "c dursun\n", "c ıtır\n", "c emel\n", "c cemil\n", "cemil ekleniyor ve iç döngüden çıkış yapılacak\n", "\n", "d ali\n", "d dursun\n", "dursun ekleniyor ve iç döngüden çıkış yapılacak\n", "\n", "e ali\n", "e dursun\n", "e ıtır\n", "e emel\n", "emel ekleniyor ve iç döngüden çıkış yapılacak\n", "\n", "['ali', 'cemil', 'dursun', 'emel']\n" ] } ], "source": [ "liste=[]\n", "for x in list(\"bacde\"):\n", " for z in [\"ali\",\"dursun\",\"ıtır\",\"emel\",\"cemil\"]:\n", " print(x,z) #kontrol için\n", " if x in z:\n", " print(f\"{z} ekleniyor ve iç döngüden çıkış yapılacak\\n\")\n", " liste.append(z)\n", " break #bir kez ekledikten sonra çıkıyorum, o yüzden mükerrer ekleme olmuyor, comment/uncomment\n", " else:\n", " print(f\"{x} için iç döngüde eşleşme bulunamadı\\n\")\n", "print(liste)" ] }, { "cell_type": "markdown", "metadata": { "id": "mjNopJQ0NP1P" }, "source": [ "### tüm döngüden çıkış" ] }, { "cell_type": "code", "execution_count": 105, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T20:44:32.757763Z", "start_time": "2020-11-22T20:44:32.751738Z" }, "id": "5LPNfTxlNP1P", "outputId": "e27fdd14-4783-42e3-ebe1-064a39ca2466", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "b ali\n", "b dursun\n", "b ıtır\n", "b emel\n", "b cemil\n", "dış döngüdeki b için tur tamamlandı,sonraki için devam\n", "\n", "k ali\n", "k dursun\n", "k ıtır\n", "k emel\n", "k cemil\n", "dış döngüdeki k için tur tamamlandı,sonraki için devam\n", "\n", "c ali\n", "c dursun\n", "c ıtır\n", "c emel\n", "c cemil\n", "cemil ekleniyor ve tüm döngüden çıkış yapılacak\n", "\n", "['cemil']\n" ] } ], "source": [ "#herhangi birinin olması yeterliyse, ilk gördüğümü ekleyip çıkayım\n", "liste=[]\n", "for x in list(\"bkcde\"): #a'yı k yapalım\n", " for z in [\"ali\",\"dursun\",\"ıtır\",\"emel\",\"cemil\"]:\n", " print(x,z) #kontrol için\n", " if x in z:\n", " print(f\"{z} ekleniyor ve tüm döngüden çıkış yapılacak\\n\")\n", " liste.append(z)\n", " break\n", " else:\n", " print(f\"dış döngüdeki {x} için tur tamamlandı,sonraki için devam\\n\")\n", " continue\n", " break #iç döngüden çıkıldığında buraya gelinir\n", "\n", "print(liste)" ] }, { "cell_type": "code", "execution_count": 106, "metadata": { "id": "2dGQViEzNP1P", "outputId": "9360eadf-ac5f-419c-ad33-6a48897c0aaf", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[(11, 15, 26)]" ] }, "metadata": {}, "execution_count": 106 } ], "source": [ "#iki dizidekilerin toplamı 20den büyük olduğunda çık\n", "dizi=[[11,21,3],[5,15,6]]\n", "records=[]\n", "\n", "for j in dizi[0]:\n", " for i in dizi[1]:\n", " if j+i>20:\n", " records.append((j,i,j+i))\n", " break\n", " else:\n", " continue\n", " break\n", "\n", "records" ] }, { "cell_type": "code", "execution_count": 107, "metadata": { "id": "8hlKXqK3NP1P", "outputId": "4a648c40-68e2-4d6f-c45d-daca2aa3c36d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[(11, 15, 26)]\n" ] } ], "source": [ "#2.yöntem. bi fonk içinte return kullanmak\n", "records=[]\n", "def myfonk():\n", " dizi=[[11,21,3],[5,15,6]]\n", " for j in dizi[0]:\n", " for i in dizi[1]:\n", " if j+i>20:\n", " records.append((j,i,j+i))\n", " return\n", "\n", "myfonk()\n", "print(records)" ] }, { "cell_type": "code", "execution_count": 108, "metadata": { "id": "VARt3zaENP1P", "outputId": "e65a123a-995d-4851-a388-e0aea5dfd300", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[(11, 15, 26)]" ] }, "metadata": {}, "execution_count": 108 } ], "source": [ "#3.yöntem: exception\n", "records=[]\n", "try:\n", " dizi=[[11,21,3],[5,15,6]]\n", " for j in dizi[0]:\n", " for i in dizi[1]:\n", " if j+i>20:\n", " records.append((j,i,j+i))\n", " raise StopIteration\n", "except StopIteration: pass\n", "records" ] }, { "cell_type": "markdown", "metadata": { "id": "mIcwJJuCNP1Q" }, "source": [ "# Data Structures(Veri yapıları)" ] }, { "cell_type": "markdown", "metadata": { "id": "nUevNH8LNP1Q" }, "source": [ "## List" ] }, { "cell_type": "code", "execution_count": 109, "metadata": { "scrolled": true, "id": "I_Hf_FrTNP1Q", "outputId": "4385ba8d-80bc-4afd-aa6d-f2d75fb44d3a", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[0, 1]\n", "True\n" ] } ], "source": [ "liste=[0,1,2,3,4,5]\n", "liste.append(6)\n", "print(liste[:2]) #stringler gibi slicing yapılır\n", "print(3 in liste) #üyelik kontrolü" ] }, { "cell_type": "code", "execution_count": 110, "metadata": { "scrolled": false, "id": "ygjFXReJNP1Q", "outputId": "24d861e5-c0c8-4f20-f640-8cd268bf9a89", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "6\n", "[0, 1, 2, 3, 4, 5]\n" ] } ], "source": [ "son=liste.pop() #son elemanı çıkarıp buna atar\n", "print(son)\n", "print(liste)" ] }, { "cell_type": "code", "execution_count": 111, "metadata": { "id": "5bHi_KxkNP1Q", "outputId": "f8bb9e39-d281-491a-cb39-43a800b00a33", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[0, 3, 6, 9, 12, 15, 18, 21, 24, 27, 30, 33, 36, 39, 42, 45, 48, 51, 54, 57, 60, 63, 66, 69, 72, 75, 78, 81, 84, 87, 90, 93, 96, 99]\n" ] } ], "source": [ "rangelist=list(range(0,100,3))\n", "print(rangelist)" ] }, { "cell_type": "markdown", "metadata": { "id": "9rkABXr-NP1Q" }, "source": [ "### Sıralama" ] }, { "cell_type": "markdown", "metadata": { "id": "iX56CAqLNP1Q" }, "source": [ "Sort metodu bir listeyi kendi üstünde sıralar, sonuç olarak birşey döndürmez. yani sıralanmış listeyi bir değişkene atayamayız. sıralanmış halini başka bir değişkene atamak istersek sorted fonkisyonunu kullanırız." ] }, { "cell_type": "code", "execution_count": 112, "metadata": { "id": "2ze6WFidNP1Q", "outputId": "66c38f63-ec72-4838-c8dd-e1340b3cc9aa", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "(2, ['printy(meyveler.index(\"muz\")) #ilk gördüğün indeksi\\n']) \n", "----------\n", "1\n", " \n", "(3, ['printy(meyveler.count(\"muz\"))\\n']) \n", "----------\n", "2\n", " \n", "(5, ['printy(meyveler)\\n']) \n", "----------\n", "['armut', 'elma', 'muz', 'muz', 'portakal', 'çilek', 'üzüm']\n", " \n", "(7, ['printy(meyveler)\\n']) \n", "----------\n", "['üzüm', 'çilek', 'portakal', 'muz', 'muz', 'elma', 'armut']\n", " \n" ] } ], "source": [ "meyveler=[\"elma\",\"muz\",\"portakal\",\"çilek\",\"üzüm\",\"armut\",\"muz\"]\n", "printy(meyveler.index(\"muz\")) #ilk gördüğün indeksi\n", "printy(meyveler.count(\"muz\"))\n", "meyveler.sort()\n", "printy(meyveler)\n", "meyveler.reverse()\n", "printy(meyveler)" ] }, { "cell_type": "code", "execution_count": 113, "metadata": { "id": "ZUj2kZ3mNP1R", "outputId": "896a2021-d601-4dcf-e923-3897dc97eb3d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['üzüm', 'çilek', 'portakal', 'muz', 'muz', 'elma', 'armut']\n" ] } ], "source": [ "siralimeyveler=sorted(meyveler,reverse=True) #ayrıca tersten sırala demiş olduk. bu parametre normal sort metodunda da var\n", "print(siralimeyveler)" ] }, { "cell_type": "markdown", "metadata": { "id": "D71LXmr0NP1R" }, "source": [ "## Tuple" ] }, { "cell_type": "markdown", "metadata": { "id": "49NGZPaZNP1R" }, "source": [ "List gibi ama değişmez yapılardır yani eleman eklenip çıkarılamaz. [] yerine () veya parantezsiz" ] }, { "cell_type": "code", "execution_count": 114, "metadata": { "id": "L1XIQZIhNP1R", "outputId": "d6306de5-37e1-4010-af09-fe1a6f8afad2", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n" ] } ], "source": [ "tpl=(1,2,3)\n", "tpl2=1,2,3\n", "print(type(tpl2))" ] }, { "cell_type": "markdown", "metadata": { "id": "Gyq28VgrNP1S" }, "source": [ "## Comprehension" ] }, { "cell_type": "markdown", "metadata": { "id": "SLQwqaX-NP1S" }, "source": [ "tüm veri yapılarıyla uygulanabilir. uzun döngü yazmaktan kurtarır. c#'taki LINQ işlemlerinin benzer hatta daha güzel alternatifi" ] }, { "cell_type": "code", "execution_count": 115, "metadata": { "id": "NqPd0hjyNP1S", "outputId": "c91b871e-6f35-4792-f37c-118843c0fa38", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[0, 6, 12, 18, 24, 30, 36, 42, 48, 54, 60, 66, 72, 78, 84, 90, 96, 102, 108, 114, 120, 126, 132, 138, 144, 150, 156, 162, 168, 174, 180, 186, 192, 198]\n" ] } ], "source": [ "rangelistinikikatı=[x*2 for x in rangelist]\n", "print(rangelistinikikatı)" ] }, { "cell_type": "markdown", "metadata": { "id": "pxwrKmaWNP1S" }, "source": [ "### koşullu comprehension" ] }, { "cell_type": "markdown", "metadata": { "id": "1WQWgwHqNP1S" }, "source": [ "[x for x in datastruct if x ...]
\n", "[x if ... else y for x in datastruct]" ] }, { "cell_type": "code", "execution_count": 116, "metadata": { "id": "HRX1WVkpNP1S", "outputId": "d6f82004-2737-45b7-b734-8643d70c7f3f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['üzüm', 'muz', 'muz', 'elma']" ] }, "metadata": {}, "execution_count": 116 } ], "source": [ "kısaisimlimeyveler=[x for x in meyveler if len(x)<5]\n", "kısaisimlimeyveler" ] }, { "cell_type": "code", "execution_count": 117, "metadata": { "scrolled": true, "id": "JVjanVF3NP1T", "outputId": "9d2fa365-40ef-415a-d66e-56d12bf2578f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[1, 3, 5, 7, 9]\n", "[1, '', 3, '', 5, '', 7, '', 9]\n" ] } ], "source": [ "liste=range(1,10)\n", "sadecetekler=[sayı for sayı in liste if sayı % 2 !=0] #tek if\n", "tekler=[sayı if sayı%2!=0 else \"\" for sayı in liste] #if-else\n", "print(sadecetekler)\n", "print(tekler)" ] }, { "cell_type": "markdown", "metadata": { "id": "IheriaOWNP1T" }, "source": [ "### içiçe(nested) list comprehension" ] }, { "cell_type": "markdown", "metadata": { "id": "EmbFdo9XNP1T" }, "source": [ "****syntax:[x for iç in dış for x in iç]****" ] }, { "cell_type": "markdown", "metadata": { "id": "0TagRdcuNP1T" }, "source": [ "2 boyutlu bir matrisi düzleştirmek istiyorum
\n", "matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
\n", "Beklediğimiz çıktı: flatten_matrix = [1, 2, 3, 4, 5, 6, 7, 8, 9]" ] }, { "cell_type": "code", "execution_count": 118, "metadata": { "id": "jPpkAqNKNP1T", "outputId": "921ba5ce-8183-4552-85b8-29a770fdc6d6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[1, 2, 3, 4, 5, 6, 7, 8, 9]\n" ] } ], "source": [ "# 2-D List\n", "matrix = [[1, 2, 3], [4, 5], [6, 7, 8, 9]]\n", "\n", "flatten_matrix = []\n", "\n", "for sublist in matrix:\n", "\tfor val in sublist:\n", "\t\tflatten_matrix.append(val)\n", "\n", "print(flatten_matrix)\n" ] }, { "cell_type": "code", "execution_count": 119, "metadata": { "id": "7z41QOV3NP1U", "outputId": "320e7517-697b-4ffc-bdf5-f5c0dc3293b2", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[1, 2, 3, 4, 5, 6, 7, 8, 9]\n" ] } ], "source": [ "# 2-D List\n", "matrix = [[1, 2, 3], [4, 5], [6, 7, 8, 9]]\n", "\n", "# Nested List Comprehension to flatten a given 2-D matrix\n", "flatten_matrix = [val for sublist in matrix for val in sublist]\n", "\n", "print(flatten_matrix)" ] }, { "cell_type": "code", "execution_count": 120, "metadata": { "id": "-hA1EVDlNP1U", "outputId": "7ee51822-27c3-4c44-8ac0-1b1ab3a05da4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['Venus', 'Earth', 'Mars', 'Pluto']\n" ] } ], "source": [ "# 2-D List of planets\n", "planets = [['Mercury', 'Venus', 'Earth'], ['Mars', 'Jupiter', 'Saturn'], ['Uranus', 'Neptune', 'Pluto']]\n", "\n", "flatten_planets = []\n", "\n", "for sublist in planets:\n", "\tfor planet in sublist:\n", "\n", "\t\tif len(planet) < 6:\n", "\t\t\tflatten_planets.append(planet)\n", "\n", "print(flatten_planets)" ] }, { "cell_type": "code", "execution_count": 121, "metadata": { "scrolled": true, "id": "3sF4mxwgNP1U", "outputId": "d19e9fec-d249-47b5-c1e3-dcbf37908ad0", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['Venus', 'Earth', 'Mars', 'Pluto']\n" ] } ], "source": [ "flatten_planets = [planet for sublist in planets for planet in sublist if len(planet) < 6]\n", "print(flatten_planets)" ] }, { "cell_type": "code", "execution_count": 122, "metadata": { "id": "Gm5-pZTzNP1U", "outputId": "be895b8d-96f0-432b-adaf-9ce6107b7515", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['Venus', 'Earth', 'Mars', 'Pluto']" ] }, "metadata": {}, "execution_count": 122 } ], "source": [ "kısalar=[p for iç in planets for p in iç if len(p)<6]\n", "kısalar" ] }, { "cell_type": "markdown", "metadata": { "id": "0JOWbgJqNP1V" }, "source": [ "Daha genel bir gösterim için https://stackoverflow.com/questions/18072759/list-comprehension-on-a-nested-list sayfasındaki gif animasyonlu açıklamaya bakınız" ] }, { "cell_type": "markdown", "metadata": { "id": "8gG0zt1xNP1V" }, "source": [ "### Matrisler ve matrislerde comprehension" ] }, { "cell_type": "code", "execution_count": 123, "metadata": { "id": "Mne2ty4qNP1V", "outputId": "b953d00f-fa5f-409b-ba93-f2348694a4d6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "3\n", "(7, ['printy([satır for satır in matris]) #satır satır\\n']) \n", "----------\n", "[[1, 2, 3], [4, 5, 6], [7, 8, 9]]\n", " \n", "(8, ['printy([satır[0] for satır in matris]) #ilk sütun\\n']) \n", "----------\n", "[1, 4, 7]\n", " \n", "(9, ['printy([[satır[i] for satır in matris] for i in range(3)]) #sütun sütun, transpozesi\\n']) \n", "----------\n", "[[1, 4, 7], [2, 5, 8], [3, 6, 9]]\n", " \n", "(10, ['printy([x for iç in matris for x in iç]) #nested\\n']) \n", "----------\n", "[1, 2, 3, 4, 5, 6, 7, 8, 9]\n", " \n" ] } ], "source": [ "matris=[\n", " [1,2,3],\n", " [4,5,6],\n", " [7,8,9]\n", "]\n", "print(len(matris))\n", "printy([satır for satır in matris]) #satır satır\n", "printy([satır[0] for satır in matris]) #ilk sütun\n", "printy([[satır[i] for satır in matris] for i in range(3)]) #sütun sütun, transpozesi\n", "printy([x for iç in matris for x in iç]) #nested" ] }, { "cell_type": "markdown", "metadata": { "id": "_LEp7Ue3NP1V" }, "source": [ "amaç aşağıdakini elde etmek olsun\n", "
\n",
        "matrix = [[0, 1, 2, 3, 4],\n",
        "          [0, 1, 2, 3, 4],\n",
        "          [0, 1, 2, 3, 4],\n",
        "          [0, 1, 2, 3, 4],\n",
        "          [0, 1, 2, 3, 4]]\n",
        "
" ] }, { "cell_type": "code", "execution_count": 124, "metadata": { "id": "OFfwnWT5NP1V", "outputId": "6d14e9aa-858d-4ba9-8a3a-495f7e807a1b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[[0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4]]\n" ] } ], "source": [ "matrix = []\n", "\n", "for i in range(5):\n", "\n", "\t# Append an empty sublist inside the list\n", "\tmatrix.append([])\n", "\n", "\tfor j in range(5):\n", "\t\tmatrix[i].append(j)\n", "\n", "print(matrix)\n" ] }, { "cell_type": "code", "execution_count": 125, "metadata": { "id": "pTZObgruNP1V", "outputId": "87fc9d2b-96d8-4a04-824d-c914309e2a6d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[[0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4]]\n" ] } ], "source": [ "# Nested list comprehension\n", "matrix = [[j for j in range(5)] for i in range(5)]\n", "\n", "print(matrix)" ] }, { "cell_type": "markdown", "metadata": { "id": "bOPaavfoNP1W" }, "source": [ "### Generators" ] }, { "cell_type": "markdown", "metadata": { "id": "JVGurksxNP1W" }, "source": [ "Bu konu biraz daha advanced bi konu olup ben sadece toplam alınması gereken durumlar için bir öenride bulunucam. Bi list comprehension sonunda(özellikle çok büyük bi list sözkonusuya) toplam alınacaksa [] kullanamya gerek yok, böylece memory tasarrufu yapmış olursunuz. Detaylar için şu sayfaya bakabilirsiniz: https://www.johndcook.com/blog/2020/01/15/generator-expression/" ] }, { "cell_type": "code", "execution_count": 126, "metadata": { "id": "5wo-U8QoNP1X", "outputId": "a535516b-294b-47ab-d45b-ae7ebfc5bcb7", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "285" ] }, "metadata": {}, "execution_count": 126 } ], "source": [ "#list comprehension: tüm liste elemanları bellekte tutuluyor\n", "sum([x**2 for x in range(10)])" ] }, { "cell_type": "code", "execution_count": 127, "metadata": { "id": "tVNCqHRENP1X", "outputId": "93732567-cba1-476c-a131-381e128270c6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "285" ] }, "metadata": {}, "execution_count": 127 } ], "source": [ "#generator expression: liste elemanları bellekte tutulmuyor\n", "sum(x**2 for x in range(10))" ] }, { "cell_type": "markdown", "metadata": { "id": "w_aH2KmvNP1X" }, "source": [ "## Stack" ] }, { "cell_type": "markdown", "metadata": { "id": "koT7RrSyNP1X" }, "source": [ "Normalde böyle bi sınıf yok. list'i stack gibi kullanırız. append ve pop sayesinde. ilk giren ilk çıkar" ] }, { "cell_type": "code", "execution_count": 128, "metadata": { "id": "AOYlOLN2NP1X", "outputId": "b546321f-c5e3-41a5-914f-cf564248245d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "4" ] }, "metadata": {}, "execution_count": 128 }, { "output_type": "execute_result", "data": { "text/plain": [ "[1, 2, 3]" ] }, "metadata": {}, "execution_count": 128 } ], "source": [ "stack=[1,2,3]\n", "stack.append(4)\n", "stack.pop()\n", "stack" ] }, { "cell_type": "markdown", "metadata": { "id": "m9mI5senNP1Y" }, "source": [ "## Queue" ] }, { "cell_type": "markdown", "metadata": { "id": "fhGjV581NP1Y" }, "source": [ "Bunu da istersek listten yaparız, ilk giren son çıkar. ama bunun için collections modülünde bi sınıf var" ] }, { "cell_type": "code", "execution_count": 129, "metadata": { "id": "yWhScMN7NP1Y", "outputId": "76ffb7b1-8748-426f-bf3d-33c5331c3868", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "1\n", "deque([2, 3, 4])\n" ] } ], "source": [ "from collections import deque\n", "kuyruk=deque([1,2,3])\n", "kuyruk.append(4)\n", "sıradaki=kuyruk.popleft()\n", "print(sıradaki)\n", "print(kuyruk)" ] }, { "cell_type": "markdown", "metadata": { "id": "Cdl9pcc0NP1Y" }, "source": [ "## Dictionary" ] }, { "cell_type": "markdown", "metadata": { "id": "SUa2Se8GNP1Y" }, "source": [ "Key-value ikililerini tutarlar. Sırasızdırlar(EDIT:Python 3.7den itibaren girdilen sırayı korur), indeksle ulaşamayız. key'lerle valuelara ulaşırız veya döngü içinde dolanarak ikisine birden tek seferde de ulaşabiliriz." ] }, { "cell_type": "markdown", "metadata": { "id": "kwb7sDe9NP1Y" }, "source": [ "### Yaratım" ] }, { "cell_type": "markdown", "metadata": { "id": "nJUUXyxBNP1Z" }, "source": [ "#### Klasik" ] }, { "cell_type": "code", "execution_count": 130, "metadata": { "id": "o_7JO3-LNP1Z", "outputId": "ab3f9c0c-f6c8-4e24-a158-9a6a4a603349", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "(5, ['printy(dict_.keys())\\n']) \n", "----------\n", "dict_keys(['one', 'two'])\n", " \n", "(6, ['printy(dict_.values())\\n']) \n", "----------\n", "dict_values(['bir', 'zwei'])\n", " \n", "(7, ['printy(dict_.items())\\n']) \n", "----------\n", "dict_items([('one', 'bir'), ('two', 'zwei')])\n", " \n", "bir\n", "N/A\n" ] } ], "source": [ "dict_={}\n", "dict_[\"one\"]=\"bir\" #add,append, insert gibi bir metodu yok, direkt atanıyor\n", "dict_[\"two\"]=\"iki\"\n", "dict_[\"two\"]=\"zwei\"\n", "printy(dict_.keys())\n", "printy(dict_.values())\n", "printy(dict_.items())\n", "print(dict_[\"one\"])\n", "#print(dict_[\"three\"]) # hata alır, almaması için get kullan\n", "print(dict_.get(\"three\",\"N/A\"))" ] }, { "cell_type": "markdown", "metadata": { "id": "uDsCwp-BNP1Z" }, "source": [ "#### dict metodu ile ikili elemanlardan oluşan bir yapıdan" ] }, { "cell_type": "markdown", "metadata": { "id": "knXEsR2TNP1Z" }, "source": [ "bu ikili yapılar genelde zip veya enumerate olacaktır. bakınız ilgili fonksiyonar." ] }, { "cell_type": "code", "execution_count": 131, "metadata": { "id": "I4q3Wwo7NP1Z", "outputId": "1388f47f-3570-4675-dfba-2ce248167b92", "colab": { "base_uri": "https://localhost:8080/", "height": 53 } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n" ] }, { "output_type": "execute_result", "data": { "text/plain": [ "'bir'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 131 } ], "source": [ "tpl=[(\"one\",\"bir\"),(\"two\",\"iki\"),(\"three\",\"üç\")]\n", "dict_=dict(tpl)\n", "print(type(dict_))\n", "dict_[\"one\"]" ] }, { "cell_type": "markdown", "metadata": { "id": "l4Z0Cw0PNP1Z" }, "source": [ "#### comprehension ile" ] }, { "cell_type": "code", "execution_count": 132, "metadata": { "id": "2cwYcIVFNP1Z", "outputId": "17ba06de-e090-4352-d7ed-90b2a88419e4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "dict_items([(0, 0), (2, 4), (4, 16), (6, 36), (8, 64)])\n" ] } ], "source": [ "sayılar=list(range(10))\n", "ciftlerinkaresi={x: x**2 for x in sayılar if x%2==0}\n", "print(ciftlerinkaresi.items())" ] }, { "cell_type": "markdown", "metadata": { "id": "qncIYxruNP1a" }, "source": [ "### elemanlarda dolaşma" ] }, { "cell_type": "code", "execution_count": 133, "metadata": { "id": "TSXUJrk_NP1a", "outputId": "e427ec17-1015-41d3-bc73-de3470135ec6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "0 0\n", "2 4\n", "4 16\n", "6 36\n", "8 64\n" ] } ], "source": [ "for k,v in ciftlerinkaresi.items():\n", " print(k,v)" ] }, { "cell_type": "markdown", "metadata": { "id": "nadIvmlzNP1a" }, "source": [ "### çeşitli metodlar" ] }, { "cell_type": "code", "execution_count": 134, "metadata": { "id": "V9iUJKtpNP1a", "outputId": "b1a454ed-a461-4dc4-d4bd-834c0242ff72", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "dict_items([])" ] }, "metadata": {}, "execution_count": 134 }, { "output_type": "stream", "name": "stdout", "text": [ "name 'ciftlerinkaresi' is not defined\n" ] } ], "source": [ "try:\n", " ciftlerinkaresi.clear()\n", " ciftlerinkaresi.items()\n", " del ciftlerinkaresi\n", " ciftlerinkaresi #hata verir, artık bellekten uçtu\n", "except Exception as err:\n", " print(err)" ] }, { "cell_type": "markdown", "metadata": { "id": "6M08JSXFNP1a" }, "source": [ "## Set" ] }, { "cell_type": "markdown", "metadata": { "id": "H8O819D9NP1a" }, "source": [ "Bunlar da dict gibi sırasızdır. dict gibi {} içinde tanımlanırlar. uniqe değerleri tutarlar. bir listteki duplikeleri ayırmak ve membership kontrolü için çok kullanılırlar" ] }, { "cell_type": "code", "execution_count": 135, "metadata": { "id": "tYuMoLaTNP1a", "outputId": "c5ed3a78-a497-4df3-b7b9-0a392b43b42b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{1, 2, 3, 4, 5}" ] }, "metadata": {}, "execution_count": 135 } ], "source": [ "liste=[1,1,2,3,4,4,5]\n", "set_=set(liste)\n", "set_" ] }, { "cell_type": "code", "execution_count": 136, "metadata": { "scrolled": true, "id": "PLLzA6DqNP1b", "outputId": "638755e6-20ea-4fef-dcc9-30f9bd21df7b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "(5, ['printy(set1,set2,set3)\\n']) \n", "----------\n", "{1, 2, 3, 4, 5} {2, 3, 4} {2, 3, 4, 5, 6}\n", " \n", "(6, ['printy(\"----diff\")\\n']) \n", "----------\n", "----diff\n", " \n", "(7, ['printy(set1.difference(set2))\\n']) \n", "----------\n", "{1, 5}\n", " \n", "(8, ['printy(set1.difference(set3))\\n']) \n", "----------\n", "{1}\n", " \n", "(9, ['printy(set2.difference(set1))\\n']) \n", "----------\n", "set()\n", " \n", "(10, ['printy(set2.difference(set3))\\n']) \n", "----------\n", "set()\n", " \n", "(11, ['printy(set3.difference(set1))\\n']) \n", "----------\n", "{6}\n", " \n", "(12, ['printy(set3.difference(set2))\\n']) \n", "----------\n", "{5, 6}\n", " \n", "(13, ['printy(\"- intersection----\")\\n']) \n", "----------\n", "- intersection----\n", " \n", "(14, ['printy(set1.intersection(set2))\\n']) \n", "----------\n", "{2, 3, 4}\n", " \n", "(15, ['printy(set1.intersection(set3))\\n']) \n", "----------\n", "{2, 3, 4, 5}\n", " \n", "(16, ['printy(set2.intersection(set1))\\n']) \n", "----------\n", "{2, 3, 4}\n", " \n", "(17, ['printy(set2.intersection(set3))\\n']) \n", "----------\n", "{2, 3, 4}\n", " \n", "(18, ['printy(set3.intersection(set1))\\n']) \n", "----------\n", "{2, 3, 4, 5}\n", " \n", "(19, ['printy(set3.intersection(set2))\\n']) \n", "----------\n", "{2, 3, 4}\n", " \n", "(20, ['printy(\"----union---\")\\n']) \n", "----------\n", "----union---\n", " \n", "(21, ['printy(set1.union(set2))\\n']) \n", "----------\n", "{1, 2, 3, 4, 5}\n", " \n", "(22, ['printy(set1.union(set3))\\n']) \n", "----------\n", "{1, 2, 3, 4, 5, 6}\n", " \n", "(23, ['printy(set2.union(set1))\\n']) \n", "----------\n", "{1, 2, 3, 4, 5}\n", " \n", "(24, ['printy(set2.union(set3))\\n']) \n", "----------\n", "{2, 3, 4, 5, 6}\n", " \n", "(25, ['printy(set3.union(set1))\\n']) \n", "----------\n", "{1, 2, 3, 4, 5, 6}\n", " \n", "(26, ['printy(set3.union(set2))\\n']) \n", "----------\n", "{2, 3, 4, 5, 6}\n", " \n" ] } ], "source": [ "set1={1,2,3,4,5}\n", "set2={2,3,4}\n", "set3={2,3,4,5,6}\n", "\n", "printy(set1,set2,set3)\n", "printy(\"----diff\")\n", "printy(set1.difference(set2))\n", "printy(set1.difference(set3))\n", "printy(set2.difference(set1))\n", "printy(set2.difference(set3))\n", "printy(set3.difference(set1))\n", "printy(set3.difference(set2))\n", "printy(\"- intersection----\")\n", "printy(set1.intersection(set2))\n", "printy(set1.intersection(set3))\n", "printy(set2.intersection(set1))\n", "printy(set2.intersection(set3))\n", "printy(set3.intersection(set1))\n", "printy(set3.intersection(set2))\n", "printy(\"----union---\")\n", "printy(set1.union(set2))\n", "printy(set1.union(set3))\n", "printy(set2.union(set1))\n", "printy(set2.union(set3))\n", "printy(set3.union(set1))\n", "printy(set3.union(set2))" ] }, { "cell_type": "markdown", "metadata": { "id": "g2M7EbFbNP1b" }, "source": [ "Not: Yukarıdaki altalta aynı hizada olan tüm printy ifadesini tek seferde yapmanın yolu var. ben mesela bunların hepsi print iken printy'yi tek seferde yaptım. Alt tuşuna basarak seçmek. aşağıdaki gibi seçip t tuşuna basarsam tüm ty'ler t olur." ] }, { "cell_type": "markdown", "metadata": { "id": "SgE1e1v8NP1b" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "BNbPUbLBNP1b" }, "source": [ "## Zip" ] }, { "cell_type": "code", "execution_count": 137, "metadata": { "id": "PEvEjCdmNP1c" }, "outputs": [], "source": [ "x=[1,2,3]\n", "y=[10,20,30]\n", "onkatlar=zip(x,y)\n", "#print(list(onkatlar)) #yazdırmak için liste çevir. bi kez liste çevirlince artık zip özelliği kalmaz,\n", "#o yüzden alttaki blok çalışmaz,o yüzden geçici olarak commentledim. deneyin ve görün" ] }, { "cell_type": "code", "execution_count": 138, "metadata": { "id": "O7BG__WUNP1c", "outputId": "4ccf793d-465e-4ebe-d047-99ef439b8b40", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "(1, 2, 3)" ] }, "metadata": {}, "execution_count": 138 } ], "source": [ "#tekrar ayırmak için\n", "x2, y2 = zip(*onkatlar)\n", "x2" ] }, { "cell_type": "markdown", "metadata": { "id": "JGOPan-RNP1c" }, "source": [ "### Zip vs Dict" ] }, { "cell_type": "code", "execution_count": 139, "metadata": { "id": "rzotDh-vNP1c", "outputId": "5627cbb1-ca84-4325-f235-61737dc2d5f5", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "1 10\n", "2 20\n", "3 30\n" ] } ], "source": [ "a=[1,2,3]\n", "b=[10,20,30]\n", "c=zip(a,b)\n", "for i,j in c:\n", " print(i,j)" ] }, { "cell_type": "code", "execution_count": 140, "metadata": { "id": "yaVPVoMiNP1d", "outputId": "0910ea05-e1fe-462a-d98e-65f5548e1f13", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n" ] } ], "source": [ "a=[1,2,3]\n", "b=[10,20,30]\n", "c=zip(a,b)\n", "print(type(list(c)[0]))\n", "dict_=dict(c) #zipten dict üretimi\n", "for k,v in dict_.items():\n", " print(k,v)" ] }, { "cell_type": "markdown", "metadata": { "id": "DAIKLenQNP1d" }, "source": [ "## Listlerle kullanılan önemli fonksiyonlar" ] }, { "cell_type": "markdown", "metadata": { "id": "7Ik8QJWvNP1d" }, "source": [ "### Map ve Reduce" ] }, { "cell_type": "markdown", "metadata": { "id": "feqvx2VsNP1d" }, "source": [ "Map: bir veri yapısındaki elemanları sırayla bir fonksiyona gönderir ve sonuç yine bir veri yapısıdır
\n", "Reduce: elemanları sırayla gönderir, bir eritme mantığı var, her bir önceki elamnını sonucyla bir sonraki eleman işleme girer" ] }, { "cell_type": "markdown", "metadata": { "id": "aTuNdPsxNP1d" }, "source": [ "#### Map" ] }, { "cell_type": "code", "execution_count": 141, "metadata": { "id": "A5_yqtr9NP1e", "outputId": "92a6faa2-d3f2-400d-bf19-1da66ae9744a", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[1, 4, 9, 16, 25]" ] }, "metadata": {}, "execution_count": 141 } ], "source": [ "items=[1,2,3,4,5]\n", "def kareal(sayı):\n", " return sayı**2\n", "\n", "kareler=map(kareal,items) #lambdalı da olur. map(lambda x: x**2, items)\n", "list(kareler) #yazdırmak için liste çevir\n" ] }, { "cell_type": "code", "execution_count": 142, "metadata": { "id": "aAd1opFtNP1e", "outputId": "ab89bb40-c032-4755-efbc-337228e912ac", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "1\n", "6\n", "15\n", "28\n", "45\n", "66\n", "91\n", "120\n", "153\n" ] } ], "source": [ "#birden fazla veri yapısı da girebilir işleme\n", "range1=range(1,10)\n", "range2=range(1,20,2)\n", "\n", "mymap=map(lambda x,y:x*y,range1,range2)\n", "for i in mymap:\n", " print(i)" ] }, { "cell_type": "code", "execution_count": 143, "metadata": { "id": "XCiepbUMNP1e", "outputId": "aebaa2d4-038b-435f-9d61-8f8decdfc920", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[1, 6, 15, 28, 45, 66, 91, 120, 153]" ] }, "metadata": {}, "execution_count": 143 } ], "source": [ "#comprehensionla da yapılabilir.\n", "çarpım=[x*y for x,y in zip(range1,range2)]\n", "çarpım" ] }, { "cell_type": "code", "execution_count": 144, "metadata": { "scrolled": true, "id": "8a4dlVGBNP1e", "outputId": "33d10e22-9ea5-4e5a-f610-5fcf372d1830", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o']" ] }, "metadata": {}, "execution_count": 144 } ], "source": [ "harfler=map(chr,range(97,112))\n", "list(harfler)" ] }, { "cell_type": "code", "execution_count": 145, "metadata": { "id": "GQa0tF0xNP1e", "outputId": "c8eef550-d3b7-40c0-fd43-7d7d2c7ca4e4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o']" ] }, "metadata": {}, "execution_count": 145 } ], "source": [ "harfler2=[chr(x) for x in range(97,112)]\n", "harfler2" ] }, { "cell_type": "markdown", "metadata": { "id": "hsRSWXPYNP1f" }, "source": [ "#### Reduce" ] }, { "cell_type": "code", "execution_count": 146, "metadata": { "id": "k-33ZD62NP1f", "outputId": "bbf6ec4f-8b8d-4f9a-bb64-a0e294142b28", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "362880" ] }, "metadata": {}, "execution_count": 146 } ], "source": [ "from functools import reduce\n", "def faktoriyel(sayı1,sayı2):\n", " return sayı1*sayı2\n", "\n", "sayılar=range(1,10)\n", "fakt=reduce(faktoriyel,sayılar)\n", "fakt" ] }, { "cell_type": "markdown", "metadata": { "id": "wx8xOTGGNP1f" }, "source": [ "#### Filter" ] }, { "cell_type": "code", "execution_count": 147, "metadata": { "ExecuteTime": { "end_time": "2020-12-04T17:50:33.788733Z", "start_time": "2020-12-04T17:50:33.783746Z" }, "id": "tQB2akYENP1f", "outputId": "b90a7a49-d3c6-4c28-a9f8-dcd583b16bef", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "18\n", "24\n", "32\n" ] } ], "source": [ "ages = [5, 12, 17, 18, 24, 32]\n", "\n", "def myFunc(x):\n", " if x < 18:\n", " return False\n", " else:\n", " return True\n", "\n", "adults = filter(myFunc, ages)\n", "\n", "for x in adults:\n", " print(x)" ] }, { "cell_type": "code", "execution_count": 148, "metadata": { "ExecuteTime": { "end_time": "2020-12-04T17:51:27.064547Z", "start_time": "2020-12-04T17:51:27.060518Z" }, "id": "4F6I7k98NP1f", "outputId": "0af51789-c6f1-4b02-8a53-dbd2bd39af36", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[18, 24, 32]" ] }, "metadata": {}, "execution_count": 148 } ], "source": [ "#veya lambda ile\n", "list(filter(lambda x:x>=18,ages))" ] }, { "cell_type": "markdown", "metadata": { "id": "FmA92zRANP1f" }, "source": [ "### Enumerate" ] }, { "cell_type": "code", "execution_count": 149, "metadata": { "scrolled": true, "id": "WMSPL5qrNP1g", "outputId": "1bc437fa-9a6f-402a-869e-cfa3f97e40d6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[(1, 'Ocak'), (2, 'Şubat'), (3, 'Mart')]\n", "1 Ocak\n", "2 Şubat\n", "3 Mart\n" ] } ], "source": [ "aylar=[\"Ocak\",\"Şubat\",\"Mart\"]\n", "print(list(enumerate(aylar,start=1)))\n", "dict_=dict(enumerate(aylar,start=1))\n", "for k,v in dict_.items():\n", " print(k,v)" ] }, { "cell_type": "markdown", "metadata": { "id": "y41iO0qPNP1g" }, "source": [ "### All ve Any" ] }, { "cell_type": "code", "execution_count": 150, "metadata": { "id": "vjuEJ-uPNP1g", "outputId": "0c136fee-c30e-4df5-c75d-d635a15afd6f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "False\n", "True\n", "True\n" ] } ], "source": [ "liste1=[True,True,False]\n", "liste2=[True,True,True]\n", "print(all(liste1))\n", "print(any(liste1))\n", "print(all(liste2))" ] }, { "cell_type": "markdown", "metadata": { "id": "GOOpbi13NP1g" }, "source": [ "# Date Time işlemleri" ] }, { "cell_type": "markdown", "metadata": { "id": "0nLGJSCiNP1g" }, "source": [ "## Modüller ve üyeleri" ] }, { "cell_type": "code", "execution_count": 151, "metadata": { "id": "u9LRhmkENP1g" }, "outputs": [], "source": [ "import datetime\n", "import time\n", "import timeit\n", "import dateutil\n", "import calendar\n", "#import timer as tr #bu threadlerle ilgili kullanma, settimer ve killtimer var" ] }, { "cell_type": "markdown", "source": [ "bunlardan en çok kullanılan datetime olup, bu modül içinde bir de datetime tipi vardır. HAngisini import edeceğinize karar vermek önemli. ernizde olsam sadece modül olanı import eder, sonraki alt tip ve diğer üyeleri bunun üzeirnden çağırırım" ], "metadata": { "id": "ABTWlGHd8PiA" } }, { "cell_type": "markdown", "metadata": { "id": "ogHsS-WWNP1h" }, "source": [ "### datetime" ] }, { "cell_type": "code", "execution_count": 152, "metadata": { "id": "KuI7TPyGNP1h", "outputId": "01d3bd66-b733-4d74-a905-c7bb1d6bf53f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['MAXYEAR', 'MINYEAR', 'date', 'datetime', 'datetime_CAPI', 'sys', 'time', 'timedelta', 'timezone', 'tzinfo']\n" ] } ], "source": [ "print([i for i in dir(datetime) if not \"__\" in i])" ] }, { "cell_type": "code", "execution_count": 153, "metadata": { "id": "XMeABvTLNP1i", "outputId": "52fe2452-770a-4d64-9be8-2c5f4f7056b5", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "datetime.datetime(2024, 9, 22, 15, 25, 25, 30003)" ] }, "metadata": {}, "execution_count": 153 }, { "output_type": "execute_result", "data": { "text/plain": [ "15" ] }, "metadata": {}, "execution_count": 153 }, { "output_type": "execute_result", "data": { "text/plain": [ "datetime.date(2024, 9, 22)" ] }, "metadata": {}, "execution_count": 153 }, { "output_type": "execute_result", "data": { "text/plain": [ "2024" ] }, "metadata": {}, "execution_count": 153 }, { "output_type": "execute_result", "data": { "text/plain": [ "datetime.date(2019, 4, 3)" ] }, "metadata": {}, "execution_count": 153 } ], "source": [ "datetime.datetime.now()\n", "datetime.datetime.now().hour #saliseden yıla kadar hepsi elde edilebili\n", "datetime.date.today()\n", "datetime.date.today().year\n", "datetime.date(2019,4,3)" ] }, { "cell_type": "code", "source": [ "datetime.datetime.now().day # yada dt.date.today().day" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "OLx1qWvFUANF", "outputId": "32a42b07-955e-42a7-ff89-b1358fe450db" }, "execution_count": 154, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "22" ] }, "metadata": {}, "execution_count": 154 } ] }, { "cell_type": "markdown", "metadata": { "id": "Zx00B2efNP1i" }, "source": [ "### time (süre ölçümlerinde bunu kullancaz, bundaki time metodunu)" ] }, { "cell_type": "code", "execution_count": 155, "metadata": { "id": "o4y2YQ-4NP1i", "outputId": "7c121e27-cf33-4adb-97e2-64b755f4d742", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['CLOCK_BOOTTIME', 'CLOCK_MONOTONIC', 'CLOCK_MONOTONIC_RAW', 'CLOCK_PROCESS_CPUTIME_ID', 'CLOCK_REALTIME', 'CLOCK_TAI', 'CLOCK_THREAD_CPUTIME_ID', '_STRUCT_TM_ITEMS', 'altzone', 'asctime', 'clock_getres', 'clock_gettime', 'clock_gettime_ns', 'clock_settime', 'clock_settime_ns', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'monotonic_ns', 'perf_counter', 'perf_counter_ns', 'process_time', 'process_time_ns', 'pthread_getcpuclockid', 'sleep', 'strftime', 'strptime', 'struct_time', 'thread_time', 'thread_time_ns', 'time', 'time_ns', 'timezone', 'tzname', 'tzset']\n" ] } ], "source": [ "print([i for i in dir(time) if not \"__\" in i])" ] }, { "cell_type": "code", "execution_count": 156, "metadata": { "id": "qCo8RMt8NP1i", "outputId": "1136be26-57ad-4342-d58f-11359319431d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['Timer', '_globals', 'default_number', 'default_repeat', 'default_timer', 'dummy_src_name', 'gc', 'itertools', 'main', 'reindent', 'repeat', 'sys', 'template', 'time', 'timeit']\n" ] } ], "source": [ "print([i for i in dir(timeit) if not \"__\" in i])" ] }, { "cell_type": "markdown", "metadata": { "id": "pS9EitMsNP1i" }, "source": [ "### dateutil" ] }, { "cell_type": "code", "execution_count": 157, "metadata": { "id": "flMnC1jgNP1i", "outputId": "6a2d948d-df98-4cac-e53c-1633d214e6f5", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['_common', '_version', 'parser', 'relativedelta', 'tz']\n" ] } ], "source": [ "print([i for i in dir(dateutil) if not \"__\" in i])" ] }, { "cell_type": "markdown", "source": [ "### Calendar" ], "metadata": { "id": "LgyH2682UQhd" } }, { "cell_type": "code", "source": [ "calendar.mdays" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "Q7L5Sj7nUQAa", "outputId": "005203f0-d728-42ed-b805-37916fea1b3e" }, "execution_count": 158, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]" ] }, "metadata": {}, "execution_count": 158 } ] }, { "cell_type": "code", "source": [ "calendar.Calendar().monthdayscalendar(datetime.date.today().year,datetime.date.today().month)" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "tIvUKaF4UaX8", "outputId": "17fcb4fa-827b-4e7e-f56b-29e28fff1dcf" }, "execution_count": 159, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[[0, 0, 0, 0, 0, 0, 1],\n", " [2, 3, 4, 5, 6, 7, 8],\n", " [9, 10, 11, 12, 13, 14, 15],\n", " [16, 17, 18, 19, 20, 21, 22],\n", " [23, 24, 25, 26, 27, 28, 29],\n", " [30, 0, 0, 0, 0, 0, 0]]" ] }, "metadata": {}, "execution_count": 159 } ] }, { "cell_type": "code", "source": [ "#bu aydaki gün sayısı\n", "calendar.mdays[datetime.date.today().month]" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "NfRlfsy55_W8", "outputId": "02f4c58c-1d6d-4227-ee8c-e72652b8e3db" }, "execution_count": 160, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "30" ] }, "metadata": {}, "execution_count": 160 } ] }, { "cell_type": "markdown", "source": [ "### Tarih farkları" ], "metadata": { "id": "iCldvgMoTMx0" } }, { "cell_type": "code", "source": [ "datetime.date.today()-datetime.date(2024,4,3)" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "QCoSkQIKTMV4", "outputId": "ba10e902-b1fd-4bda-ace6-8b27a375941c" }, "execution_count": 161, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "datetime.timedelta(days=172)" ] }, "metadata": {}, "execution_count": 161 } ] }, { "cell_type": "code", "source": [ "#gün farkını alalım\n", "(datetime.date.today()-datetime.date(2024,4,3)).days" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "cHH11kgV6nn6", "outputId": "89f9132a-2171-4a68-fa02-70d131b0c10a" }, "execution_count": 162, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "172" ] }, "metadata": {}, "execution_count": 162 } ] }, { "cell_type": "code", "source": [ "#30 gün sonrası\n", "datetime.date.today()+datetime.timedelta(days=30)\n", "#1 ay sonra(bazen 30, bazen 31, hatta 28/29 olabilir)\n", "datetime.date.today()+datetime.timedelta(days=calendar.mdays[datetime.date.today().month])" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "G3c0_TWmTUhk", "outputId": "fdba2571-5c11-43e3-a4f4-52e8e231f1b3" }, "execution_count": 163, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "datetime.date(2024, 10, 22)" ] }, "metadata": {}, "execution_count": 163 }, { "output_type": "execute_result", "data": { "text/plain": [ "datetime.date(2024, 10, 22)" ] }, "metadata": {}, "execution_count": 163 } ] }, { "cell_type": "markdown", "source": [ "### Dönüşümler" ], "metadata": { "id": "FgQkOvgZ7TKO" } }, { "cell_type": "code", "source": [ "# strftime: datetime nesnesini string'e dönüştürme\n", "now = datetime.datetime.now()\n", "date_string = now.strftime(\"%Y-%m-%d %H:%M:%S\")\n", "print(date_string)\n", "\n", "# strptime: string'i datetime nesnesine dönüştürme\n", "date_string = \"2023-10-26 15:30:00\"\n", "datetime_object = datetime.datetime.strptime(date_string, \"%Y-%m-%d %H:%M:%S\")\n", "print(datetime_object, type(datetime_object))" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "4ob8gIMu7XP4", "outputId": "d650b3ac-2d5b-434e-99fd-394927d8a177" }, "execution_count": 164, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "2024-09-22 15:25:25\n", "2023-10-26 15:30:00 \n" ] } ] }, { "cell_type": "markdown", "source": [ "**datetime.strptime** fonksiyonu, belirli bir formattaki tarih ve saat bilgilerini ayrıştırmak için kullanılırken, yukarıda gördüğümüz **dateutil.parser** fonksiyonu daha genel bir ayrıştırıcıdır ve birçok farklı formatı tanıyabilir.\n", "\n", "**dateutil.parser** fonksiyonu, **datetime.strptime** fonksiyonundan daha esnektir ve daha fazla tarih ve saat formatını destekler. Ayrıca, dateutil.parser fonksiyonu, bilinmeyen formattaki tarih ve saat bilgilerini ayrıştırmak için de kullanılabilir.\n" ], "metadata": { "id": "x8FxG4UrA5ka" } }, { "cell_type": "code", "source": [ "from_util = dateutil.parser.parse(date_string)\n", "print(from_util, type(from_util))" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "P4IavL9iAAFe", "outputId": "d2a3bcfc-ca74-4b10-c9dd-8a5d6fb5761e" }, "execution_count": 165, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "2023-10-26 15:30:00 \n" ] } ] }, { "cell_type": "markdown", "metadata": { "id": "UK2fWkAVNP1j" }, "source": [ "## Süre ölçümü" ] }, { "cell_type": "markdown", "metadata": { "id": "bhG0hYSwNP1j" }, "source": [ "### Performans amaçlı süre ölçümü(sonuçtan bağımsız)" ] }, { "cell_type": "markdown", "metadata": { "id": "MMxYbw0eNP1j" }, "source": [ "- `%'li` olanı bir fonksiyon takip eder, `%%'li` kullanımda ise alt satırdan yazarsın.\n", "- `Time` olan tek seferlik run'ın süresini verirken `timeit` onlarca kez çalıştırıp ortalama süre verir" ] }, { "cell_type": "code", "execution_count": 166, "metadata": { "id": "dBc-f8JzNP1j", "outputId": "565ae13b-c342-404f-a191-f82fbf2b3d80", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "37.7 ms ± 2.34 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)\n" ] } ], "source": [ "%%timeit\n", "x=sum(range(1000000))" ] }, { "cell_type": "code", "execution_count": 167, "metadata": { "ExecuteTime": { "end_time": "2020-09-02T18:59:00.443453Z", "start_time": "2020-09-02T18:59:00.277897Z" }, "id": "QBiH7YAkNP1j", "outputId": "b5a5a8d6-4608-4660-be9d-04603599e209", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "CPU times: user 35.5 ms, sys: 0 ns, total: 35.5 ms\n", "Wall time: 35.6 ms\n" ] } ], "source": [ "%%time\n", "x=sum(range(1000000))" ] }, { "cell_type": "code", "execution_count": 168, "metadata": { "id": "2PXDCsVTNP1k", "outputId": "4293a549-6a2f-490e-ad2d-c9feff7fd4fa", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "25.7 ms ± 7.89 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)\n" ] } ], "source": [ "def hesapla():\n", " y=sum(range(1000000))\n", "\n", "%timeit hesapla()" ] }, { "cell_type": "markdown", "metadata": { "id": "ubb3G85qNP1k" }, "source": [ "### Süreyle birlikte sonuç görme" ] }, { "cell_type": "code", "execution_count": 169, "metadata": { "id": "4h98INXtNP1k", "outputId": "27237b24-a405-4a5e-ccb7-cbeead847909", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "hey\n", "süre:0.019402027130126953\n" ] } ], "source": [ "bas=time.time()\n", "print(\"hey\")\n", "hesapla()\n", "bit=time.time()\n", "print(\"süre:{}\".format(bit-bas))" ] }, { "cell_type": "markdown", "metadata": { "id": "VSthGf9ZNP1k" }, "source": [ "### jupyter nbextensions" ] }, { "cell_type": "markdown", "metadata": { "id": "hmbvwVIcNP1k" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "DJqzb_e3NP1l" }, "source": [ "nbextensionsı hala kurmadıysanız alın size bir sebep daha. bu süre ölçümü kodlarına gerek yok. yukarıdaki eklentiyle her hücrenin çalışma süresini veriyor. Bir örnek:" ] }, { "cell_type": "markdown", "metadata": { "id": "ku4FWmrvNP1l" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "5jd7IUY-NP1l" }, "source": [ "# Önemli bazı modüller" ] }, { "cell_type": "markdown", "metadata": { "id": "9flgVhIsNP1l" }, "source": [ "Aşağıda önemli olduğunu düşündüğüm bazı modülleri bulacaksınız. Tabiki bunların dışında da başak kütüphaneler/modüller var, bunları da zamanla öğreneceksiniz." ] }, { "cell_type": "markdown", "metadata": { "id": "zIBmaEyINP1l" }, "source": [ "## os" ] }, { "cell_type": "markdown", "metadata": { "id": "ETNToPtcNP1m" }, "source": [ "İşletim sisteminden bağımsız çalışacak bir koda(dosyalama sistemi v.s ile ilgili) ihtiyacımız olduğunda os modülünü kullanırız." ] }, { "cell_type": "markdown", "metadata": { "id": "hvw5ofEoNP1m" }, "source": [ "### Klasör ve dosya işlemleri" ] }, { "cell_type": "code", "execution_count": 170, "metadata": { "id": "idhsE3pENP1m", "outputId": "72ec3d22-1dc3-46c1-b56e-ac3f98e17786", "colab": { "base_uri": "https://localhost:8080/", "height": 53 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'/content'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 170 }, { "output_type": "execute_result", "data": { "text/plain": [ "'.'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 170 } ], "source": [ "import os\n", "os.getcwd() #o anki aktif folder\n", "os.curdir #mevcut dizini temsil eden karakter, genelde bu . oluyor. Bunu daha çok prefix path olarak kullanırız" ] }, { "cell_type": "code", "source": [ "os.listdir() #o anki aktif folderdaki dosyaları listeler" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "YRnxg8nGITn8", "outputId": "978b5141-6a0d-45a9-b24f-9c2df3dbbe1e" }, "execution_count": 171, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['.config', 'drive', 'sample_data']" ] }, "metadata": {}, "execution_count": 171 } ] }, { "cell_type": "code", "execution_count": 172, "metadata": { "id": "0oHJDb3zNP1m", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "2a8c7a49-1c9f-4bcd-ae15-61eee8b06a4e" }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['Othercomputers',\n", " '.file-revisions-by-id',\n", " 'MyDrive',\n", " '.shortcut-targets-by-id',\n", " '.Trash-0']" ] }, "metadata": {}, "execution_count": 172 } ], "source": [ "os.chdir(\"drive\") #aktif klasörü değiştiriyoruz\n", "os.listdir()" ] }, { "cell_type": "code", "execution_count": 173, "metadata": { "id": "MJ9SFSM1NP1m", "outputId": "274ebbb8-ea9d-4cd2-9290-b1ebd7033088", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'..'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 173 } ], "source": [ "os.pardir #parent klasörü temsil eden karakter" ] }, { "cell_type": "code", "execution_count": 174, "metadata": { "id": "Ey3N5KpINP1n", "outputId": "83ec6a2f-9800-417d-dad9-266ce94edb9c", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['.config', 'drive', 'sample_data']" ] }, "metadata": {}, "execution_count": 174 } ], "source": [ "os.listdir(os.pardir)" ] }, { "cell_type": "code", "execution_count": 175, "metadata": { "id": "n3LZWSB3NP1n", "outputId": "afccb4c8-66e6-40a5-81b3-34f2d3a74a7c", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "False" ] }, "metadata": {}, "execution_count": 175 } ], "source": [ "os.path.exists('Python Genel.ipynb') #bir dosya/klasör mevcut mu" ] }, { "cell_type": "code", "execution_count": 176, "metadata": { "id": "ZnWb90SkNP1n", "outputId": "2fdc4f0c-407c-465a-c648-f689bc660556", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "False" ] }, "metadata": {}, "execution_count": 176 } ], "source": [ "os.path.isfile('olmayandosya.txt') #parametredeki bir dosya mı? veya bir dosya mevcut mu anlamında da kullanılabilir." ] }, { "cell_type": "code", "execution_count": 177, "metadata": { "id": "XhSxCvnqNP1n", "outputId": "fd06880b-bbd7-4773-aa31-482526f71ca4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "False" ] }, "metadata": {}, "execution_count": 177 } ], "source": [ "os.path.isdir(\"klasor\")" ] }, { "cell_type": "code", "execution_count": 178, "metadata": { "id": "9TEIONcbNP1n", "outputId": "7e1d8090-d275-48ff-c63a-6908af1cac11", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[]\n" ] } ], "source": [ "# list all files in a directory in Python.\n", "from os import listdir\n", "from os.path import isfile, join\n", "p=os.getcwd()\n", "files_list = [f for f in listdir(p) if isfile(join(p, f))]\n", "print(files_list);" ] }, { "cell_type": "code", "execution_count": 179, "metadata": { "scrolled": true, "id": "pjdzqreQNP1o", "outputId": "87141785-3f64-4fe3-cd05-8acf35fb12ab", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/content/drive/MyDrive/Colab Notebooks\n", "/content/drive/MyDrive/Colab Notebooks/.config\n", "/content/drive/MyDrive/Colab Notebooks/.config/startup\n" ] } ], "source": [ "dizin= \"/content/drive/MyDrive/Colab Notebooks\"\n", "for kökdizin, altdizinler, dosyalar in os.walk(dizin):\n", " print(kökdizin)" ] }, { "cell_type": "code", "execution_count": 180, "metadata": { "id": "uBHDharYNP1o", "outputId": "390d5cbc-b628-4c14-e6ae-a18c11c88a57", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/content/drive/MyDrive/Colab Notebooks/Snippets: Drive adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/Snippets: Accessing files adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/Data Table Display adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/Forms adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/gemini.ipynb adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/Harici veriler: Yerel Dosyalar, Drive, E-Tablolar ve Cloud Storage adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/_My Custom Snippets.ipynb\n", "/content/drive/MyDrive/Colab Notebooks/_Colab Aboneliğinizden En İyi Şekilde Yararlanma\n", "/content/drive/MyDrive/Colab Notebooks/_pathler, drive, github.ipynb\n", "/content/drive/MyDrive/Colab Notebooks/pandas.ipynb adlı not defterinin kopyası\n", "/content/drive/MyDrive/Colab Notebooks/.config/startup/starters.py\n" ] } ], "source": [ "for kökdizin, altdizinler, dosyalar in os.walk(dizin):\n", " for dosya in dosyalar:\n", " print(os.sep.join([kökdizin, dosya]))" ] }, { "cell_type": "code", "source": [ "%cd \"MyDrive\"" ], "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "_UCgZfRxJX2f", "outputId": "81d5ee3e-bdb6-45ef-bcf1-84b5e89f6dec" }, "execution_count": 181, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "/content/drive/MyDrive\n" ] } ] }, { "cell_type": "code", "source": [ "!touch abc.txt #dosya yaratalım" ], "metadata": { "id": "5_X3DvwpIrwo" }, "execution_count": 182, "outputs": [] }, { "cell_type": "code", "execution_count": 183, "metadata": { "scrolled": true, "id": "qluw2XfeNP1o", "outputId": "d35987c6-867c-462e-b4c1-4be768a54ea2", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Last modified: 1727018731.0\n", "Created: Sun Sep 22 15:25:31 2024\n" ] } ], "source": [ "import os.path, time, datetime\n", "print(\"Last modified: %s\" % os.path.getmtime(\"abc.txt\")) #formatlanmamış\n", "print(\"Created: %s\" % time.ctime(os.path.getctime(\"abc.txt\")))" ] }, { "cell_type": "code", "source": [ "!rm abc.txt #tekrar silelim" ], "metadata": { "id": "cBXWgS90JqmK" }, "execution_count": 184, "outputs": [] }, { "cell_type": "code", "execution_count": 185, "metadata": { "id": "WyqHfL5gNP1o" }, "outputs": [], "source": [ "#Sadece windowsta. Linux için-->https://stackoverflow.com/questions/17317219/is-there-an-platform-independent-equivalent-of-os-startfile\n", "# os.startfile('calc.exe') #dosya açar, program başaltır, internet sitesine gider v.s" ] }, { "cell_type": "code", "execution_count": 186, "metadata": { "id": "YM8SBcjENP1o" }, "outputs": [], "source": [ "# os.startfile(\"/falanca/klasördeki/filanca/dosya\")" ] }, { "cell_type": "code", "execution_count": 187, "metadata": { "id": "NgmG0Uw_NP1p" }, "outputs": [], "source": [ "# os.startfile(\"www.volkanyurtseven.com\")" ] }, { "cell_type": "markdown", "metadata": { "id": "qwCvraQ9NP1p" }, "source": [ "### Sistem ve Environment bilgileri" ] }, { "cell_type": "code", "execution_count": 188, "metadata": { "scrolled": true, "id": "kLkITj7VNP1p", "outputId": "e2edc182-1e94-4361-8007-a142c568a7b6", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "posix\n", "Linux\n", "6.1.85+\n" ] } ], "source": [ "import platform, os\n", "print(os.name)\n", "print(platform.system())\n", "print(platform.release())" ] }, { "cell_type": "code", "execution_count": 189, "metadata": { "id": "B7-oLbonNP1p", "outputId": "7cb1bc7e-8f7a-461d-86a8-d493052061c4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{'SHELL': '/bin/bash',\n", " 'NV_LIBCUBLAS_VERSION': '12.2.5.6-1',\n", " 'NVIDIA_VISIBLE_DEVICES': 'all',\n", " 'COLAB_JUPYTER_TRANSPORT': 'ipc',\n", " 'NV_NVML_DEV_VERSION': '12.2.140-1',\n", " 'NV_CUDNN_PACKAGE_NAME': 'libcudnn8',\n", " 'CGROUP_MEMORY_EVENTS': '/sys/fs/cgroup/memory.events /var/colab/cgroup/jupyter-children/memory.events',\n", " 'NV_LIBNCCL_DEV_PACKAGE': 'libnccl-dev=2.19.3-1+cuda12.2',\n", " 'NV_LIBNCCL_DEV_PACKAGE_VERSION': '2.19.3-1',\n", " 'VM_GCE_METADATA_HOST': '169.254.169.253',\n", " 'HOSTNAME': '51c8695c6b32',\n", " 'LANGUAGE': 'en_US',\n", " 'TBE_RUNTIME_ADDR': '172.28.0.1:8011',\n", " 'COLAB_TPU_1VM': '',\n", " 'GCE_METADATA_TIMEOUT': '3',\n", " 'NVIDIA_REQUIRE_CUDA': 'cuda>=12.2 brand=tesla,driver>=470,driver<471 brand=unknown,driver>=470,driver<471 brand=nvidia,driver>=470,driver<471 brand=nvidiartx,driver>=470,driver<471 brand=geforce,driver>=470,driver<471 brand=geforcertx,driver>=470,driver<471 brand=quadro,driver>=470,driver<471 brand=quadrortx,driver>=470,driver<471 brand=titan,driver>=470,driver<471 brand=titanrtx,driver>=470,driver<471 brand=tesla,driver>=525,driver<526 brand=unknown,driver>=525,driver<526 brand=nvidia,driver>=525,driver<526 brand=nvidiartx,driver>=525,driver<526 brand=geforce,driver>=525,driver<526 brand=geforcertx,driver>=525,driver<526 brand=quadro,driver>=525,driver<526 brand=quadrortx,driver>=525,driver<526 brand=titan,driver>=525,driver<526 brand=titanrtx,driver>=525,driver<526',\n", " 'NV_LIBCUBLAS_DEV_PACKAGE': 'libcublas-dev-12-2=12.2.5.6-1',\n", " 'NV_NVTX_VERSION': '12.2.140-1',\n", " 'COLAB_JUPYTER_IP': '172.28.0.12',\n", " 'NV_CUDA_CUDART_DEV_VERSION': '12.2.140-1',\n", " 'NV_LIBCUSPARSE_VERSION': '12.1.2.141-1',\n", " 'COLAB_LANGUAGE_SERVER_PROXY_ROOT_URL': 'http://172.28.0.1:8013/',\n", " 'NV_LIBNPP_VERSION': '12.2.1.4-1',\n", " 'NCCL_VERSION': '2.19.3-1',\n", " 'KMP_LISTEN_PORT': '6000',\n", " 'TF_FORCE_GPU_ALLOW_GROWTH': 'true',\n", " 'ENV': '/root/.bashrc',\n", " 'PWD': '/',\n", " 'TBE_EPHEM_CREDS_ADDR': '172.28.0.1:8009',\n", " 'COLAB_LANGUAGE_SERVER_PROXY_REQUEST_TIMEOUT': '30s',\n", " 'TBE_CREDS_ADDR': '172.28.0.1:8008',\n", " 'NV_CUDNN_PACKAGE': 'libcudnn8=8.9.6.50-1+cuda12.2',\n", " 'NVIDIA_DRIVER_CAPABILITIES': 'compute,utility',\n", " 'COLAB_JUPYTER_TOKEN': '',\n", " 'LAST_FORCED_REBUILD': '20240627',\n", " 'NV_NVPROF_DEV_PACKAGE': 'cuda-nvprof-12-2=12.2.142-1',\n", " 'NV_LIBNPP_PACKAGE': 'libnpp-12-2=12.2.1.4-1',\n", " 'NV_LIBNCCL_DEV_PACKAGE_NAME': 'libnccl-dev',\n", " 'TCLLIBPATH': '/usr/share/tcltk/tcllib1.20',\n", " 'NV_LIBCUBLAS_DEV_VERSION': '12.2.5.6-1',\n", " 'NVIDIA_PRODUCT_NAME': 'CUDA',\n", " 'COLAB_KERNEL_MANAGER_PROXY_HOST': '172.28.0.12',\n", " 'NV_LIBCUBLAS_DEV_PACKAGE_NAME': 'libcublas-dev-12-2',\n", " 'NV_CUDA_CUDART_VERSION': '12.2.140-1',\n", " 'COLAB_WARMUP_DEFAULTS': '1',\n", " 'HOME': '/root',\n", " 'LANG': 'en_US.UTF-8',\n", " 'COLUMNS': '100',\n", " 'CUDA_VERSION': '12.2.2',\n", " 'CLOUDSDK_CONFIG': '/content/.config',\n", " 'NV_LIBCUBLAS_PACKAGE': 'libcublas-12-2=12.2.5.6-1',\n", " 'NV_CUDA_NSIGHT_COMPUTE_DEV_PACKAGE': 'cuda-nsight-compute-12-2=12.2.2-1',\n", " 'COLAB_RELEASE_TAG': 'release-colab_20240919-060125_RC00',\n", " 'KMP_TARGET_PORT': '9000',\n", " 'KMP_EXTRA_ARGS': '--logtostderr --listen_host=172.28.0.12 --target_host=172.28.0.12 --tunnel_background_save_url=https://colab.research.google.com/tun/m/cc48301118ce562b961b3c22d803539adc1e0c19/m-s-2x16lz196cw9 --tunnel_background_save_delay=10s --tunnel_periodic_background_save_frequency=30m0s --enable_output_coalescing=true --output_coalescing_required=true --gorilla_ws_opt_in --log_code_content',\n", " 'NV_LIBNPP_DEV_PACKAGE': 'libnpp-dev-12-2=12.2.1.4-1',\n", " 'COLAB_LANGUAGE_SERVER_PROXY_LSP_DIRS': '/datalab/web/pyright/typeshed-fallback/stdlib,/usr/local/lib/python3.10/dist-packages',\n", " 'NV_LIBCUBLAS_PACKAGE_NAME': 'libcublas-12-2',\n", " 'COLAB_KERNEL_MANAGER_PROXY_PORT': '6000',\n", " 'CLOUDSDK_PYTHON': 'python3',\n", " 'NV_LIBNPP_DEV_VERSION': '12.2.1.4-1',\n", " 'NO_GCE_CHECK': 'False',\n", " 'PYTHONPATH': '/env/python',\n", " 'NV_LIBCUSPARSE_DEV_VERSION': '12.1.2.141-1',\n", " 'LIBRARY_PATH': '/usr/local/cuda/lib64/stubs',\n", " 'NV_CUDNN_VERSION': '8.9.6.50',\n", " 'SHLVL': '0',\n", " 'NV_CUDA_LIB_VERSION': '12.2.2-1',\n", " 'COLAB_LANGUAGE_SERVER_PROXY': '/usr/colab/bin/language_service',\n", " 'NVARCH': 'x86_64',\n", " 'NV_CUDNN_PACKAGE_DEV': 'libcudnn8-dev=8.9.6.50-1+cuda12.2',\n", " 'NV_CUDA_COMPAT_PACKAGE': 'cuda-compat-12-2',\n", " 'NV_LIBNCCL_PACKAGE': 'libnccl2=2.19.3-1+cuda12.2',\n", " 'LD_LIBRARY_PATH': '/usr/local/nvidia/lib:/usr/local/nvidia/lib64',\n", " 'COLAB_GPU': '',\n", " 'NV_CUDA_NSIGHT_COMPUTE_VERSION': '12.2.2-1',\n", " 'GCS_READ_CACHE_BLOCK_SIZE_MB': '16',\n", " 'NV_NVPROF_VERSION': '12.2.142-1',\n", " 'LC_ALL': 'en_US.UTF-8',\n", " 'COLAB_FILE_HANDLER_ADDR': 'localhost:3453',\n", " 'PATH': '/opt/bin:/usr/local/nvidia/bin:/usr/local/cuda/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/tools/node/bin:/tools/google-cloud-sdk/bin',\n", " 'NV_LIBNCCL_PACKAGE_NAME': 'libnccl2',\n", " 'COLAB_DEBUG_ADAPTER_MUX_PATH': '/usr/local/bin/dap_multiplexer',\n", " 'NV_LIBNCCL_PACKAGE_VERSION': '2.19.3-1',\n", " 'PYTHONWARNINGS': 'ignore:::pip._internal.cli.base_command',\n", " 'DEBIAN_FRONTEND': 'noninteractive',\n", " 'COLAB_BACKEND_VERSION': 'next',\n", " 'OLDPWD': '/',\n", " 'JPY_PARENT_PID': '92',\n", " 'TERM': 'xterm-color',\n", " 'CLICOLOR': '1',\n", " 'PAGER': 'cat',\n", " 'GIT_PAGER': 'cat',\n", " 'MPLBACKEND': 'module://ipykernel.pylab.backend_inline',\n", " 'ENABLE_DIRECTORYPREFETCHER': '1',\n", " 'USE_AUTH_EPHEM': '1',\n", " 'PYDEVD_USE_FRAME_EVAL': 'NO'}" ] }, "metadata": {}, "execution_count": 189 } ], "source": [ "dict(os.environ)" ] }, { "cell_type": "code", "execution_count": 190, "metadata": { "id": "PrSwwZeBNP1p" }, "outputs": [], "source": [ "# print(dict(os.environ)[\"HOMEPATH\"])\n", "# print(dict(os.environ)[\"USERNAME\"])" ] }, { "cell_type": "markdown", "metadata": { "id": "QkXjdGPuNP1p" }, "source": [ "## random" ] }, { "cell_type": "code", "execution_count": 191, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T15:44:49.592635Z", "start_time": "2020-11-22T15:44:49.579668Z" }, "id": "3rj9nepQNP1q", "outputId": "3fff8a56-1bb1-45bf-9dce-6e95b2f5eee2", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "10\n", "13\n", "8\n", "[3, 1, 3]\n", "0.37961522332372777\n", "2.6298644191144316\n", "[3, 3]\n" ] } ], "source": [ "import random\n", "dizi=[3,5,8,3,2,1,9]\n", "random.seed(1)\n", "print(random.randint(2,48)) #2 ile 48 arasında\n", "print(random.randrange(1,100,3))\n", "print(random.choice(dizi))\n", "print(random.choices(dizi,k=3)) #çektiğini geri koyar, sampledan farkı bu, o yüzden aynısı çıkabilir\n", "print(random.random()) #0-1 arası\n", "print(random.uniform(2,5)) #2-5 arası küsurlu sayı\n", "print(random.sample(dizi,2)) #çektiğini geri koymaz, choicestan farkı bu" ] }, { "cell_type": "code", "execution_count": 192, "metadata": { "id": "Chjq0qoINP1r", "outputId": "45695dcb-97e3-44a1-df0d-64479541b198", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[2, 5, 8, 3, 1, 3, 9]" ] }, "metadata": {}, "execution_count": 192 } ], "source": [ "#liste karıştırmak\n", "random.shuffle(dizi)\n", "dizi" ] }, { "cell_type": "markdown", "metadata": { "id": "zIVd55b_NP1r" }, "source": [ "## array" ] }, { "cell_type": "markdown", "metadata": { "id": "yEQlL9_LNP1r" }, "source": [ "listin hemen hemen aynısı olup önemli bir farkı, içine sadece belli tipte eleman almasıdır. Bu yüzden memory performansı açısından liste göre daha iyidir.ancak list'ler daha hızlıdır. Ayrıca sayısal bir dizi kullanacaksanız numpy kullanmanızı tavsiye ederim. Bunun dışıdna çok büyük metinsel diziler oluşturacaksanız array kullanabilirsinz." ] }, { "cell_type": "code", "execution_count": 193, "metadata": { "id": "Aehg6NoUNP1r", "outputId": "67cb0480-235a-4ccc-9e7f-99631a36be54", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "92 88\n" ] } ], "source": [ "from array import array\n", "import sys\n", "arr=array('i',[1,2,3])\n", "lst=[1,2,3]\n", "print(sys.getsizeof(arr),sys.getsizeof(lst)) #arr'ın memory kullanımı daha düşüktür" ] }, { "cell_type": "markdown", "metadata": { "id": "Wwf1DhqXNP1r" }, "source": [ "## collections" ] }, { "cell_type": "code", "execution_count": 194, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T12:42:13.976560Z", "start_time": "2020-11-22T12:42:13.970578Z" }, "id": "OigSvt6TNP1r", "outputId": "03e468fd-4d7e-4764-ca7a-2dad1d4a37fb", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "2" ] }, "metadata": {}, "execution_count": 194 } ], "source": [ "my_list = [\"a\",\"b\",\"c\",\"c\",\"e\",\"c\",\"b\",\"b\",\"a\"]\n", "my_list.count(\"a\")" ] }, { "cell_type": "code", "execution_count": 195, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T12:42:42.671252Z", "start_time": "2020-11-22T12:42:42.668256Z" }, "id": "MKziwSJ3NP1r", "outputId": "1aa014a1-2768-4f65-e9fd-fdea33bf3fb8", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Counter({'b': 3, 'c': 3, 'a': 2, 'e': 1})\n", "2\n" ] } ], "source": [ "from collections import Counter\n", "\n", "cn = Counter(my_list) #dictionary benzeri bir yapı. tüm dictionary metodları kullanılabilir\n", "print(cn)\n", "print(cn[\"a\"]) #yukarda list ile yaptığımızın aynısı" ] }, { "cell_type": "code", "execution_count": 196, "metadata": { "id": "29BWc8LiNP1r", "outputId": "66290e3b-9233-4adb-9629-606a4b561366", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "Counter({'sen': 3, 'seni': 2, 'bil': 1, 'bilmezsen': 1, 'kendini': 1})" ] }, "metadata": {}, "execution_count": 196 } ], "source": [ "str_ = \"sen seni bil sen seni sen bilmezsen kendini\"\n", "cn = Counter(str_.split(' '))\n", "cn" ] }, { "cell_type": "code", "execution_count": 197, "metadata": { "id": "y0tSvEiiNP1s", "outputId": "533830e2-2567-4395-a2a7-a9890728fc31", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[('sen', 3), ('seni', 2)]\n", "['sen', 'seni', 'bil', 'bilmezsen', 'kendini']\n", "{'sen': 3, 'seni': 2, 'bil': 1, 'bilmezsen': 1, 'kendini': 1}\n" ] } ], "source": [ "print(cn.most_common(2)) #en çok kullanılan 2 kelime\n", "print(list(cn)) #key değerlerinin listeye çevrilmiş hali\n", "print(dict(cn)) #key-value değerlerinin sözlüğe çevrilmiş hali" ] }, { "cell_type": "code", "execution_count": 198, "metadata": { "id": "0yot3vKfNP1s", "outputId": "c4d448b4-05e1-46c3-cc0a-23b8600d4c62", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "a 4\n", "c 3\n", "b 2\n", "----\n", "a 4\n", "c 3\n", "b 2\n" ] } ], "source": [ "#OrderDict'e artık ihtiyaç yoktur. Python 3.7den itibaren de dictioanryye girilen sırayı korumaktadır\n", "#aşağıdaki örnekten de görebiliyoruz\n", "from collections import OrderedDict\n", "liste = [\"a\",\"c\",\"c\",\"a\",\"b\",\"a\",\"a\",\"b\",\"c\"]\n", "cnt = Counter(liste)\n", "od = OrderedDict(cnt.most_common())\n", "d=dict(cnt.most_common())\n", "for key, value in od.items():\n", " print(key, value)\n", "print(\"----\")\n", "for key, value in d.items():\n", " print(key, value)" ] }, { "cell_type": "code", "execution_count": 199, "metadata": { "id": "stMs_GdcNP1s", "outputId": "620cbbeb-3e0c-49cf-8f92-8d9a2fe84fad", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "John\n" ] } ], "source": [ "from collections import namedtuple\n", "\n", "Student = namedtuple('Student', 'fname, lname, age') #class yapısına benzer bir kullanım. indeks ezberlemeye son!\n", "s1 = Student('John', 'Clarke', '13')\n", "print(s1.fname)" ] }, { "cell_type": "markdown", "metadata": { "id": "by8Up3HxNP1s" }, "source": [ "## itertools" ] }, { "cell_type": "markdown", "metadata": { "id": "XjRcEeAlNP1s" }, "source": [ "### Permütasyon" ] }, { "cell_type": "code", "execution_count": 200, "metadata": { "id": "NCwAzv4bNP1t", "outputId": "728eec2b-54e6-4dc2-d4bf-8df05907000e", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "[('A', 'B', 'C'), ('A', 'C', 'B'), ('B', 'A', 'C'), ('B', 'C', 'A'), ('C', 'A', 'B'), ('C', 'B', 'A')]\n", "[('A', 'B'), ('A', 'C'), ('B', 'A'), ('B', 'C'), ('C', 'A'), ('C', 'B')]\n" ] } ], "source": [ "from itertools import permutations #sadece tekrarsızlar yapılabiliyor. n!/(n-r)!\n", "liste=[\"A\",\"B\",\"C\"]\n", "per1=list(permutations(liste))\n", "per2=list(permutations(liste,2))\n", "print(per1)\n", "print(per2)" ] }, { "cell_type": "markdown", "metadata": { "id": "oYYgBnk7NP1t" }, "source": [ "### Kombinasyon" ] }, { "cell_type": "code", "execution_count": 201, "metadata": { "id": "jpiwGFjSNP1t", "outputId": "105dd14f-1704-4385-f7a9-6b2482333805", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[('A', 'B'), ('A', 'C'), ('B', 'C')]" ] }, "metadata": {}, "execution_count": 201 } ], "source": [ "from itertools import combinations #n!/(r!*(n-r)!)\n", "com=list(combinations(liste,2))\n", "com" ] }, { "cell_type": "markdown", "metadata": { "id": "oySaIniiNP1t" }, "source": [ "### Kartezyen çarpım" ] }, { "cell_type": "code", "execution_count": 202, "metadata": { "id": "imyEWmAzNP1t", "outputId": "fa1d5c39-5245-4174-a288-040494180a60", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[('A', 2000),\n", " ('A', 2001),\n", " ('A', 2002),\n", " ('A', 2003),\n", " ('B', 2000),\n", " ('B', 2001),\n", " ('B', 2002),\n", " ('B', 2003),\n", " ('C', 2000),\n", " ('C', 2001),\n", " ('C', 2002),\n", " ('C', 2003)]" ] }, "metadata": {}, "execution_count": 202 } ], "source": [ "from itertools import product\n", "list1=[\"A\",\"B\",\"C\"]\n", "list2=[2000,2001,2002,2003]\n", "krt=list(product(list1,list2))\n", "krt" ] }, { "cell_type": "markdown", "metadata": { "id": "8c-v2GPbNP1u" }, "source": [ "## Regex (Düzenli ifadeler)" ] }, { "cell_type": "markdown", "metadata": { "id": "T7ffL3MvNP1u" }, "source": [ "Pythona özgü değildir, hemen her dilde implementasyonu vardır. Başlı başına büyük bi konudur. Burada özet vermeye çalışıcam. İleride Text mining, NLP v.s çalışacaksanız iyi öğrenmenizde fayda var" ] }, { "cell_type": "markdown", "metadata": { "id": "yYTdlQvRNP1u" }, "source": [ "### Isınma" ] }, { "cell_type": "code", "execution_count": 203, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T14:55:50.942122Z", "start_time": "2020-11-22T14:55:50.939128Z" }, "id": "LstCA0g5NP1u" }, "outputs": [], "source": [ "import re" ] }, { "cell_type": "code", "execution_count": 204, "metadata": { "id": "cp0dScCoNP1u" }, "outputs": [], "source": [ "a=\"benim adım volkan\"" ] }, { "cell_type": "code", "execution_count": 205, "metadata": { "id": "bc2oiGJMNP1u" }, "outputs": [], "source": [ "#match: başında var mı diye kontrol eder\n", "re.match(\"volkan\",a) #eşleşme yok, sonuç dönmez" ] }, { "cell_type": "code", "execution_count": 206, "metadata": { "id": "A2r-VT66NP1v", "outputId": "3e901d97-7e7e-481d-b3bb-fcf0084d58ac", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 206 } ], "source": [ "re.match(\"ben\",a) #var" ] }, { "cell_type": "code", "execution_count": 207, "metadata": { "id": "vGUREnelNP1v", "outputId": "c09044fe-487a-403d-b212-e1ebabf6fb01", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "True" ] }, "metadata": {}, "execution_count": 207 } ], "source": [ "a.startswith(\"ben\") #bu daha kullanışlıdır." ] }, { "cell_type": "code", "execution_count": 208, "metadata": { "id": "_43rk05kNP1v", "outputId": "91555923-4984-46f5-de5c-a83218bde2e9", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 208 } ], "source": [ "#search, herhangi bi yerde var mı, matche göre daha yavaş çalışır\n", "re.search(\"volkan\",a)" ] }, { "cell_type": "code", "execution_count": 209, "metadata": { "id": "eINL0Yl7NP1v", "outputId": "aefcdf3c-561f-43e3-9e87-c3df2d851fb3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "True" ] }, "metadata": {}, "execution_count": 209 } ], "source": [ "\"volkan\" in a #bu daha pratik" ] }, { "cell_type": "code", "execution_count": 210, "metadata": { "id": "hHIC0gVqNP1v", "outputId": "b85a86b4-f2bb-4088-cf10-fd8f2d4b52b8", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['sen', 'sen', 'sen', 'sen']\n", "4\n", "4\n" ] } ], "source": [ "b=\"sen seni bil sen seni\"\n", "bul=re.findall(\"sen\", b)\n", "\n", "print(bul)\n", "print(len(bul))\n", "print(b.count(\"sen\"))" ] }, { "cell_type": "markdown", "metadata": { "id": "hiAVtFvyNP1w" }, "source": [ "### Metakarakter kullanımı" ] }, { "cell_type": "code", "execution_count": 211, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T14:56:00.364786Z", "start_time": "2020-11-22T14:56:00.361819Z" }, "id": "YIAHevecNP1w" }, "outputs": [], "source": [ "isimler=[\"123a\",\"ali\",\"veli\",\"hakan\",\"volkan\",\"osman\",\"kandemir\",\"VOLkan\"]" ] }, { "cell_type": "code", "execution_count": 212, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T14:56:03.790850Z", "start_time": "2020-11-22T14:56:03.785864Z" }, "id": "5IurCv6oNP1w", "outputId": "bf8c26f5-ccfc-47e0-dae7-805166919943", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['hakan', 'volkan', 'VOLkan']" ] }, "metadata": {}, "execution_count": 212 } ], "source": [ "#kan ile bitenler, regex olmadan\n", "kan=[x for x in isimler if x[-3:]==\"kan\"]\n", "kan" ] }, { "cell_type": "markdown", "metadata": { "id": "wPMAW5iXNP1w" }, "source": [ "![resim.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "BkbwbRCTNP1w" }, "source": [ "#### [ ] Köşeli parantez" ] }, { "cell_type": "markdown", "metadata": { "id": "fw-efq3_NP1x" }, "source": [ "[] işareti, \"içine giren karakterleri içeren\" filtresi uygular. Burada önemli olan [] içinde gördügümüz tüm karaktereleri tek tek uyguluyor olmasıdır. Ör: [abc]: a veya b veya c içeren demek. [a-z]: A ile Z arasındakiler demek" ] }, { "cell_type": "code", "execution_count": 213, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T14:56:09.039799Z", "start_time": "2020-11-22T14:56:09.035811Z" }, "id": "ov68JgukNP1x", "outputId": "7dee106c-f324-4279-ae9b-4e0437b0824f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "hakan\n", "volkan\n" ] } ], "source": [ "#regex ile\n", "for i in isimler:\n", " if re.search(\"[a-z]kan\",i):\n", " print(i)\n", "#başta veya ortada bir yerde a-z arasında bir karekter olsun, sonu kan olsun demiş olduk. yani \"kan\"ın önünde bir harf\n", "#olsun da nerede olursa olsun, bşta mı ortada mı önemli değil, önemli olan kan'ın öncesinde olmaslı" ] }, { "cell_type": "code", "execution_count": 214, "metadata": { "id": "Fsvv35iGNP1y", "outputId": "384c7687-3e20-4112-ea72-3f63886637d1", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['veli', 'osman', 'kandemir']" ] }, "metadata": {}, "execution_count": 214 } ], "source": [ "#içinde e veya m geçenler, bu sefer list comprehension ile yapalım\n", "[i for i in isimler if re.search(\"[em]\",i)]" ] }, { "cell_type": "code", "execution_count": 215, "metadata": { "id": "WCYR4kscNP1y", "outputId": "02899ce3-f02f-4869-dfe1-c67cc809ef0b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['123a', 'b123', '1234']" ] }, "metadata": {}, "execution_count": 215 } ], "source": [ "#rakam içerenler\n", "liste = [\"123a\",\"b123\",\"1234\",\"volkan\"]\n", "sayıiçerenler=[x for x in liste if re.search(\"[0-9]\",x)]\n", "sayıiçerenler" ] }, { "cell_type": "code", "execution_count": 216, "metadata": { "id": "SnmWLT3YNP1y", "outputId": "111b849b-581f-4867-f9a0-e00aae075f6d", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['123a', '1234']" ] }, "metadata": {}, "execution_count": 216 } ], "source": [ "#rakam ile başlayanları bulma\n", "rakamlabaşlayanlar=[x for x in liste if re.match(\"[0-9]\",x)] #yukardakinden farklı olarak match kullandık, daha hızlı çalışır\n", "rakamlabaşlayanlar" ] }, { "cell_type": "code", "execution_count": 217, "metadata": { "id": "GcqMsXEENP1y", "outputId": "aba87780-4f1b-47be-8dc8-c20fe2c4ed94", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "['ABC', 'Abc', 'abc', '12a', 'A12', 'Ab1', 'Ab23']\n", "['Abc', 'Ab1', 'Ab23']\n", "['ABC', 'Abc', 'abc', '12a', 'A12', '123', 'Ab1', 'Ab23']\n", "['Ab1', 'Ab23']\n" ] } ], "source": [ "liste=[\"ABC\",\"Abc\",\"abc\",\"12a\",\"A12\",\"123\",\"Ab1\",\"Ab23\"]\n", "print([x for x in liste if re.search(\"[A-Za-z]\",x)]) #büyük veya küçük harf içerenler\n", "print([x for x in liste if re.search(\"[A-Z][a-z]\",x)]) #ilki büyük ikincisi küçük harf içerenler\n", "print([x for x in liste if re.search(\"[A-Za-z0-9]\",x)]) #büyük veya küçük harf veya sayı içerenler\n", "print([x for x in liste if re.search(\"[A-Z][a-z][0-9]\",x)]) #ilki büyük ikincisi küçük üçüncüsü sayı olanlar" ] }, { "cell_type": "markdown", "metadata": { "id": "9giRPBb3NP1y" }, "source": [ "#### . Nokta" ] }, { "cell_type": "markdown", "metadata": { "id": "Bo5mfg5cNP1y" }, "source": [ "\".\" tek karekteri için joker anlamındadır" ] }, { "cell_type": "code", "execution_count": 218, "metadata": { "id": "ZsSkaV5qNP1z" }, "outputs": [], "source": [ "isimler=[\"arhan\",\"volkan\",\"osman\",\"hakan\",\"demirhan\",\"1ozan\"]" ] }, { "cell_type": "code", "execution_count": 219, "metadata": { "id": "ApljdIy-NP1z", "outputId": "9f03dac5-a52a-4cb2-9197-d070c67cffa3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['arhan', 'osman', 'hakan']" ] }, "metadata": {}, "execution_count": 219 } ], "source": [ "#5 karekterli olup an ile biten gerçek isimler(gerçek isim: sayı ile başlayan birşey isim olamaz)\n", "liste=[x for x in isimler if re.match(\"[a-z]..an\",x)]\n", "liste" ] }, { "cell_type": "markdown", "metadata": { "id": "lfCcup0ANP1z" }, "source": [ "#### * Yıldız" ] }, { "cell_type": "markdown", "metadata": { "id": "Yb-V7AdfNP1z" }, "source": [ "Kendinden önce gelen 1 ifadeyi en az 0(evet 0, 1 değil) sayıda eşleştirir. Özellikle bir ifadenin yazılamayabildiği durumları da kapsamak için kullanılır. Aşağıdkai örnek gayet açıklayıcıdır." ] }, { "cell_type": "code", "execution_count": 220, "metadata": { "id": "nw9onGxYNP1z", "outputId": "6e1b138e-f400-4caa-8b2b-30adc79e354a", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['kıral', 'kral', 'kıro', 'kro', 'kritik', 'kıritik', 'kııral']" ] }, "metadata": {}, "execution_count": 220 } ], "source": [ "liste = [\"kıral\", \"kral\", \"kıro\", \"kro\", \"kırmızı\",\"kırçıllı\",\"kritik\",\"kıritik\",\"kııral\"]\n", "[x for x in liste if re.match(\"kı*r[aeıioöuü]\",x)]" ] }, { "cell_type": "markdown", "metadata": { "id": "wEXQD-HtNP10" }, "source": [ "Bu örnekte, yabancı dilden geçen kelimelerden \"kr\" ile başlayanları inceledik. Bunlar bazen aralarına ı harfi girilerek yazılabiliyor. Bu kelimelerde genelde r'den sonra sesli bi harf gelir. Biz de bunları yakalamaya çalıştık." ] }, { "cell_type": "markdown", "metadata": { "id": "LC-ketd1NP10" }, "source": [ "#### + Artı" ] }, { "cell_type": "markdown", "metadata": { "id": "WU2zW6m5NP10" }, "source": [ "Yıldıza benzer, ancak bu sefer en az 1 sayıda eşleşme yapar." ] }, { "cell_type": "code", "execution_count": 221, "metadata": { "id": "YHDg_aX3NP11", "outputId": "13cd2b57-c1eb-456e-cdd8-75010ab5629e", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['kıral', 'kıro', 'kıritik', 'kııral']" ] }, "metadata": {}, "execution_count": 221 } ], "source": [ "liste = [\"kıral\", \"kral\", \"kıro\", \"kro\", \"kırmızı\",\"kırçıllı\",\"kritik\",\"kıritik\",\"kııral\"]\n", "[x for x in liste if re.match(\"kı+r[aeıioöuü]\",x)]" ] }, { "cell_type": "code", "execution_count": 222, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T14:57:05.136600Z", "start_time": "2020-11-22T14:57:05.132611Z" }, "id": "KObxbEcsNP11", "outputId": "4ef84528-d5fe-4f7c-ad91-6697ca046e15", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "volkan\n", "hakan\n" ] } ], "source": [ "#yukardaki kan'la biten isimler örneğin. bu sefer VOLkan yazdırılır\n", "for i in isimler:\n", " if re.search(\".+kan\",i):\n", " print(i)" ] }, { "cell_type": "markdown", "metadata": { "id": "rV6ooe6aNP11" }, "source": [ "#### ? Soru işareti" ] }, { "cell_type": "markdown", "metadata": { "id": "ekAtIxZnNP11" }, "source": [ "Kendinden önce gelen karakterin 0 veya 1 kez geçtiği durumları eşleştirir." ] }, { "cell_type": "code", "execution_count": 223, "metadata": { "id": "yu6V0LzTNP11", "outputId": "aca00f6a-c436-42a9-e8b7-097197983682", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['kıral', 'kral', 'kıro', 'kro', 'kritik', 'kıritik']" ] }, "metadata": {}, "execution_count": 223 } ], "source": [ "liste = [\"kıral\", \"kral\", \"kıro\", \"kro\", \"kırmızı\",\"kırçıllı\",\"kritik\",\"kıritik\",\"kııral\"]\n", "[x for x in liste if re.match(\"kı?r[aeıioöuü]\",x)]" ] }, { "cell_type": "markdown", "metadata": { "id": "E4bdPfQoNP12" }, "source": [ "#### {} süslü parantez" ] }, { "cell_type": "markdown", "metadata": { "id": "gf5Uj6JPNP12" }, "source": [ "bir karekterin n adet geçtiği durumlar eşleştirilir." ] }, { "cell_type": "code", "execution_count": 224, "metadata": { "id": "ujabWlTENP12", "outputId": "7521267c-e0b1-49f2-ad64-353a46a5b2a9", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['kııral']" ] }, "metadata": {}, "execution_count": 224 } ], "source": [ "liste = [\"kıral\", \"kral\", \"kıro\", \"kro\", \"kırmızı\",\"kırçıllı\",\"kritik\",\"kıritik\",\"kııral\"]\n", "[x for x in liste if re.match(\"kı{2}r[aeıioöuü]\",x)]" ] }, { "cell_type": "code", "execution_count": 225, "metadata": { "id": "DXKgN-erNP12", "outputId": "cda37a34-912f-408e-d0f9-23b61883985c", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['kııral']" ] }, "metadata": {}, "execution_count": 225 } ], "source": [ "#böyle de yapılabilirdi ama n sayısı yükseldikçe {} ile yapmak daha mantıklı\n", "[x for x in liste if re.match(\"kıır[aeıioöuü]\",x)]" ] }, { "cell_type": "code", "execution_count": 226, "metadata": { "id": "lJ2-PlDENP12", "outputId": "5327b5f8-4a10-4055-d192-1af27c6ad563", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "['gool', 'gooool']" ] }, "metadata": {}, "execution_count": 226 } ], "source": [ "#{min,max}\n", "liste=[\"gol\",\"gool\",\"gooool\",\"gööl\",\"gooooooool\"]\n", "[x for x in liste if re.match(\"[a-z]o{2,5}l\",x)] #en az 2 en çok 5 oo içersin" ] }, { "cell_type": "markdown", "metadata": { "id": "KNreV4PoNP12" }, "source": [ "##### Çeşitli linkler" ] }, { "cell_type": "markdown", "metadata": { "id": "MGQ1_VJ_NP12" }, "source": [ "Regex dünyası çok büyük bi dünya, burada hepsini anlatmak yerine kısa bir girizgah yapmış olduk. Öncelikle genel oalrak regexi kavramanız sonrasında da python implementasonunu kavramanız gerekiyor. Aşağıdaki linkleri incelemenizi tavisye ederim.\n", "\n", "**Genel bilgi**\n", "- https://en.wikipedia.org/wiki/Regular_expression\n", "- https://regexr.com/ (pratik amaçlı)\n", "\n", "**Python**\n", "- https://docs.python.org/3/howto/regex.html\n", "- https://docs.python.org/3/library/re.html" ] }, { "cell_type": "markdown", "metadata": { "id": "GwqZZyGrNP12" }, "source": [ "## json" ] }, { "cell_type": "markdown", "metadata": { "id": "MH6E3UfyNP13" }, "source": [ "### jsondan pythona" ] }, { "cell_type": "markdown", "metadata": { "id": "ZN4qHLaRNP13" }, "source": [ "json yapısı python dictionary'lerine çok benzer. elde edeceğimiz nesne de bir dictionary olacaktır" ] }, { "cell_type": "code", "execution_count": 227, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:50:09.106861Z", "start_time": "2021-04-11T10:50:09.100878Z" }, "id": "oJVvrFqFNP13" }, "outputs": [], "source": [ "import json" ] }, { "cell_type": "code", "execution_count": 228, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:50:09.603020Z", "start_time": "2021-04-11T10:50:09.595037Z" }, "id": "wP1nOj35NP13", "outputId": "5edbf058-7746-4e12-fe4a-33643d07acf3", "colab": { "base_uri": "https://localhost:8080/", "height": 71 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "str" ] }, "metadata": {}, "execution_count": 228 }, { "output_type": "execute_result", "data": { "text/plain": [ "dict" ] }, "metadata": {}, "execution_count": 228 }, { "output_type": "execute_result", "data": { "text/plain": [ "'John'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 228 } ], "source": [ "#örnek bir json stringden\n", "x = '{ \"name\":\"John\", \"age\":30, \"city\":\"New York\"}'\n", "y=json.loads(x) #dcitionary olarak yükler\n", "type(x)\n", "type(y)\n", "y[\"name\"]" ] }, { "cell_type": "code", "execution_count": 231, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:51:12.111273Z", "start_time": "2021-04-11T10:51:12.102295Z" }, "id": "9TkJmx4gNP13", "outputId": "26a2d4ba-7607-418e-b62d-8f903cec694c", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "dict" ] }, "metadata": {}, "execution_count": 231 }, { "output_type": "execute_result", "data": { "text/plain": [ "{'Bolge': {'0': 'Akdeniz', '1': 'Marmara', '2': 'Akdeniz', '3': 'Marmara'},\n", " 'Yil': {'0': 2020, '1': 2020, '2': 2021, '3': 2021},\n", " 'Satis': {'0': 10, '1': 15, '2': 42, '3': 56}}" ] }, "metadata": {}, "execution_count": 231 } ], "source": [ "#veya json dosyadan. ama bu indenti dikkate almıyor, çünkü elde edilen nesne bi string değil, dictionary\n", "import io\n", "with io.open(\"/content/drive/MyDrive/Programming/PythonRocks/dataset/json/indentli_bolgesatis.json\", 'r') as f:\n", " data = json.load(f)\n", "type(data)\n", "data" ] }, { "cell_type": "code", "execution_count": 232, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:52:53.530875Z", "start_time": "2021-04-11T10:52:53.525888Z" }, "scrolled": true, "id": "hRNmBbs7NP13", "outputId": "114afbfe-5d59-4643-ba51-3020d03313f5", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "{\n", " \"Bolge\":{\n", " \"0\":\"Akdeniz\",\n", " \"1\":\"Marmara\",\n", " \"2\":\"Akdeniz\",\n", " \"3\":\"Marmara\"\n", " },\n", " \"Yil\":{\n", " \"0\":2020,\n", " \"1\":2020,\n", " \"2\":2021,\n", " \"3\":2021\n", " },\n", " \"Satis\":{\n", " \"0\":10,\n", " \"1\":15,\n", " \"2\":42,\n", " \"3\":56\n", " }\n", "}\n" ] } ], "source": [ "#indentli formatı yazdırmak istersek dosya okuması yaparak bi string içine okuruz\n", "with io.open(\"/content/drive/MyDrive/Programming/PythonRocks/dataset/json/indentli_bolgesatis.json\", mode='r') as f:\n", " content=f.read() # bu stringdir, ve indentli yapı korunmuştur\n", "print(content)" ] }, { "cell_type": "code", "execution_count": 233, "metadata": { "scrolled": true, "id": "1KVAmiwdNP14", "outputId": "4b240885-5cbc-4d9a-d41c-91efb1b36097", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "{\n", " \"columns\":[\n", " \"Bolge\",\n", " \"Yil\",\n", " \"Satis\"\n", " ],\n", " \"data\":[\n", " [\n", " \"Akdeniz\",\n", " 2020,\n", " 10\n", " ],\n", " [\n", " \"Marmara\",\n", " 2020,\n", " 15\n", " ],\n", " [\n", " \"Akdeniz\",\n", " 2021,\n", " 42\n", " ],\n", " [\n", " \"Marmara\",\n", " 2021,\n", " 56\n", " ]\n", " ]\n", "}\n" ] } ], "source": [ "#split oriented kaydedilmiş dosyadan\n", "with io.open(\"/content/drive/MyDrive/Programming/PythonRocks/dataset/json/indentli_bolgesatis_split.json\", mode='r') as f:\n", " content=f.read()\n", "print(content)" ] }, { "cell_type": "code", "execution_count": 234, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:54:03.948942Z", "start_time": "2021-04-11T10:54:03.598989Z" }, "scrolled": true, "id": "5G-iiEBINP14", "outputId": "17d65dbf-4a64-417c-f105-e290fedf1853", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "{\n", " \"schema\":{\n", " \"fields\":[\n", " {\n", " \"name\":\"Bolge\",\n", " \"type\":\"string\"\n", " },\n", " {\n", " \"name\":\"Yil\",\n", " \"type\":\"integer\"\n", " },\n", " {\n", " \"name\":\"Satis\",\n", " \"type\":\"integer\"\n", " }\n", " ],\n", " \"pandas_version\":\"0.20.0\"\n", " },\n", " \"data\":[\n", " {\n", " \"Bolge\":\"Akdeniz\",\n", " \"Yil\":2020,\n", " \"Satis\":10\n", " },\n", " {\n", " \"Bolge\":\"Marmara\",\n", " \"Yil\":2020,\n", " \"Satis\":15\n", " },\n", " {\n", " \"Bolge\":\"Akdeniz\",\n", " \"Yil\":2021,\n", " \"Satis\":42\n", " },\n", " {\n", " \"Bolge\":\"Marmara\",\n", " \"Yil\":2021,\n", " \"Satis\":56\n", " }\n", " ]\n", "}\n" ] } ], "source": [ "#table oriented kaydedilmiş dosyadan\n", "with io.open(\"/content/drive/MyDrive/Programming/PythonRocks/dataset/json/indentli_bolgesatis_table.json\", mode='r') as f:\n", " content=f.read()\n", "print(content)" ] }, { "cell_type": "code", "execution_count": 235, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:54:05.350155Z", "start_time": "2021-04-11T10:54:05.343174Z" }, "id": "Q_41Obj_NP14", "outputId": "3c9d6fb0-5467-4f71-951c-71aec5aa7a26", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "dict" ] }, "metadata": {}, "execution_count": 235 }, { "output_type": "execute_result", "data": { "text/plain": [ "{'schema': {'fields': [{'name': 'Bolge', 'type': 'string'},\n", " {'name': 'Yil', 'type': 'integer'},\n", " {'name': 'Satis', 'type': 'integer'}],\n", " 'pandas_version': '0.20.0'},\n", " 'data': [{'Bolge': 'Akdeniz', 'Yil': 2020, 'Satis': 10},\n", " {'Bolge': 'Marmara', 'Yil': 2020, 'Satis': 15},\n", " {'Bolge': 'Akdeniz', 'Yil': 2021, 'Satis': 42},\n", " {'Bolge': 'Marmara', 'Yil': 2021, 'Satis': 56}]}" ] }, "metadata": {}, "execution_count": 235 } ], "source": [ "c=json.loads(content)\n", "type(c)\n", "c" ] }, { "cell_type": "code", "execution_count": 236, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:54:13.377699Z", "start_time": "2021-04-11T10:54:13.369758Z" }, "id": "k2jY8dmbNP14", "outputId": "5cc913d8-e0b6-400f-99c4-4a5de5ac1f09", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'Akdeniz'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 236 } ], "source": [ "#içteki tek bir bilgiye ulaşma\n", "c[\"data\"][0][\"Bolge\"] #dict of list of dict" ] }, { "cell_type": "code", "execution_count": 237, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T10:54:14.362891Z", "start_time": "2021-04-11T10:54:14.358940Z" }, "id": "9THsxWPVNP15", "outputId": "d7b24dfc-50a4-4fda-945e-9d2cfd4525ca", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Akdeniz\n", "Marmara\n", "Akdeniz\n", "Marmara\n" ] } ], "source": [ "#tüm bölgeleri alma\n", "for l in c[\"data\"]:\n", " print(l[\"Bolge\"])" ] }, { "cell_type": "markdown", "metadata": { "id": "ycJ0g1LtNP15" }, "source": [ "### pythondan jsona" ] }, { "cell_type": "code", "execution_count": 238, "metadata": { "id": "6XY4uNXINP15", "outputId": "67beeaef-c239-480b-9da9-7efb469075be", "colab": { "base_uri": "https://localhost:8080/", "height": 71 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "dict" ] }, "metadata": {}, "execution_count": 238 }, { "output_type": "execute_result", "data": { "text/plain": [ "str" ] }, "metadata": {}, "execution_count": 238 }, { "output_type": "execute_result", "data": { "text/plain": [ "'{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 238 } ], "source": [ "x = {\n", " \"name\": \"John\",\n", " \"age\": 30,\n", " \"city\": \"New York\"\n", "}\n", "\n", "j = json.dumps(x)\n", "type(x)\n", "type(j)\n", "j" ] }, { "cell_type": "code", "execution_count": 239, "metadata": { "id": "ZtP7EQwpNP16", "outputId": "79ad0169-ff34-4ebb-dde9-e20dd2fb54be", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "{\"name\": \"John\", \"age\": 30, \"married\": true, \"divorced\": false, \"children\": [\"Ann\", \"Billy\"], \"pets\": null, \"cars\": [{\"model\": \"BMW 230\", \"mpg\": 27.5}, {\"model\": \"Ford Edge\", \"mpg\": 24.1}]}\n" ] } ], "source": [ "#komplike(nested) json\n", "x = {\n", " \"name\": \"John\",\n", " \"age\": 30,\n", " \"married\": True,\n", " \"divorced\": False,\n", " \"children\": (\"Ann\",\"Billy\"),\n", " \"pets\": None,\n", " \"cars\": [\n", " {\"model\": \"BMW 230\", \"mpg\": 27.5},\n", " {\"model\": \"Ford Edge\", \"mpg\": 24.1}\n", " ]\n", "}\n", "\n", "print(json.dumps(x))" ] }, { "cell_type": "code", "execution_count": 240, "metadata": { "id": "Z9HyTevzNP16", "outputId": "349dbdf7-2774-4bce-eda3-3ed06f8e6525", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "{\n", " \"name\": \"John\",\n", " \"age\": 30,\n", " \"married\": true,\n", " \"divorced\": false,\n", " \"children\": [\n", " \"Ann\",\n", " \"Billy\"\n", " ],\n", " \"pets\": null,\n", " \"cars\": [\n", " {\n", " \"model\": \"BMW 230\",\n", " \"mpg\": 27.5\n", " },\n", " {\n", " \"model\": \"Ford Edge\",\n", " \"mpg\": 24.1\n", " }\n", " ]\n", "}\n" ] } ], "source": [ "#bu da şık hali\n", "print(json.dumps(x,indent=4))" ] }, { "cell_type": "code", "execution_count": 241, "metadata": { "id": "KdCqAtjUNP16", "outputId": "33cb15d7-09c7-4631-ee98-87696ab386b5", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "{\n", " \"age\": 30,\n", " \"cars\": [\n", " {\n", " \"model\": \"BMW 230\",\n", " \"mpg\": 27.5\n", " },\n", " {\n", " \"model\": \"Ford Edge\",\n", " \"mpg\": 24.1\n", " }\n", " ],\n", " \"children\": [\n", " \"Ann\",\n", " \"Billy\"\n", " ],\n", " \"divorced\": false,\n", " \"married\": true,\n", " \"name\": \"John\",\n", " \"pets\": null\n", "}\n" ] } ], "source": [ "print(json.dumps(x,indent=4,sort_keys=True))" ] }, { "cell_type": "markdown", "metadata": { "id": "t0GIaoxuNP16" }, "source": [ "Bunları aşağıdaki I/O işlemleriyle bir dosyaya da yazdırabilirsiniz." ] }, { "cell_type": "markdown", "metadata": { "id": "W_Azx01eNP16" }, "source": [ "## Request" ] }, { "cell_type": "markdown", "metadata": { "id": "c9pQ-nD9NP17" }, "source": [ "https://realpython.com/python-requests/ sitesinden faydalandım" ] }, { "cell_type": "markdown", "metadata": { "id": "sLIO_t5oNP17" }, "source": [ "### Basics" ] }, { "cell_type": "code", "execution_count": 242, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:34:22.862704Z", "start_time": "2021-05-15T15:34:22.641341Z" }, "id": "p9pEubABNP17" }, "outputs": [], "source": [ "import requests" ] }, { "cell_type": "code", "execution_count": 243, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:34:24.362239Z", "start_time": "2021-05-15T15:34:24.358213Z" }, "id": "kFF-hydsNP17" }, "outputs": [], "source": [ "httpget0=r\"https://www.excelinefendisi.com/httpapiservice/ResponseveRequestTarget.aspx\" #buna parametre verebiliyoruz, Anakonu=VBAMakro, Altkonu=Temeller\n", "httpget0j=r\"https://www.excelinefendisi.com/httpapiservice/ReturnJson.aspx\" #tüm duyurlar as json\n", "httpget3=r\"https://httpbin.org/get\" #as json\n", "httpget4img=r\"https://httpbin.org/image\"\n", "httpget5=r\"https://www.google.com/search?q=excel&oq=excel&aqs=chrome..69i57j35i39l2j0i433l4j46i433l2j0.839j0j15&sourceid=chrome&ie=UTF-8\"\n", "httpget6githubjson=r\"https://raw.githubusercontent.com/VolkiTheDreamer/dataset/master/json/bolgesatis.json\"\n", "\n", "httppost3=r\"https://httpbin.org/post\"" ] }, { "cell_type": "code", "execution_count": 244, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:34:29.194045Z", "start_time": "2021-05-15T15:34:28.511013Z" }, "id": "suK8G-UYNP17" }, "outputs": [], "source": [ "r=requests.get(httpget3)" ] }, { "cell_type": "code", "execution_count": 245, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:34:32.053841Z", "start_time": "2021-05-15T15:34:32.048854Z" }, "id": "NFHER8uYNP17", "outputId": "3f1885af-8b11-4b33-ed6e-d151b5974f01", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{'Date': 'Sun, 22 Sep 2024 15:26:54 GMT', 'Content-Type': 'application/json', 'Content-Length': '307', 'Connection': 'keep-alive', 'Server': 'gunicorn/19.9.0', 'Access-Control-Allow-Origin': '*', 'Access-Control-Allow-Credentials': 'true'}" ] }, "metadata": {}, "execution_count": 245 } ], "source": [ "r.headers" ] }, { "cell_type": "code", "execution_count": 246, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:34:36.018195Z", "start_time": "2021-05-15T15:34:34.687476Z" }, "id": "vMb7XEH2NP18", "outputId": "bdcb0f0a-276e-4f2f-f171-d6b08c5933e3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 246 } ], "source": [ "requests.get('http://volkanyurtseven.com')" ] }, { "cell_type": "code", "execution_count": 247, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:18:33.490545Z", "start_time": "2021-04-12T11:18:32.595460Z" }, "id": "mSrSW1NGNP18", "outputId": "3d5d55ab-4d91-4742-bdfd-f98dda647142", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "site çalışmıyor\n" ] } ], "source": [ "try:\n", " requests.get('https://volkanyurtseven.com') #https versiyonu yok, hata alcaz\n", " print(\"site çalışıyor\")\n", "except:\n", " print(\"site çalışmıyor\")" ] }, { "cell_type": "code", "execution_count": 248, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:18:46.903444Z", "start_time": "2021-04-12T11:18:46.773750Z" }, "id": "t1BPrEGDNP18", "outputId": "e1bde44f-db1b-42a1-dfe9-2aa3ad1ce70b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 248 } ], "source": [ "requests.get('http://volkanyurtseven.com/olmayansayfa') #bu sefer site doğru ama bahsekonu sayfa yoksa 404" ] }, { "cell_type": "code", "execution_count": 249, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:18:52.376056Z", "start_time": "2021-04-12T11:18:52.246402Z" }, "id": "9gXqkxYYNP18", "outputId": "4cf9fce1-905a-4810-d32f-b5059d3e11e7", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "200" ] }, "metadata": {}, "execution_count": 249 } ], "source": [ "response = requests.get('http://volkanyurtseven.com')\n", "response.status_code" ] }, { "cell_type": "code", "execution_count": 250, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:50:00.510411Z", "start_time": "2021-04-12T11:50:00.239067Z" }, "scrolled": true, "id": "qVhplpG1NP19", "outputId": "595db2ba-8acb-4079-d6ee-cc1e8d78d275", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "b'{\\n \"args\": {}, \\n \"headers\": {\\n \"Accept\": \"*/*\", \\n \"Accept-Encoding\": \"gzip, deflate\", \\n \"Host\": \"httpbin.org\", \\n \"User-Agent\": \"python-requests/2.32.3\", \\n \"X-Amzn-Trace-Id\": \"Root=1-66f03742-6923173002866a3c50f6dfc5\"\\n }, \\n \"origin\": \"34.16.168.234\", \\n \"url\": \"https://httpbin.org/get\"\\n}\\n'" ] }, "metadata": {}, "execution_count": 250 } ], "source": [ "response = requests.get(httpget3)\n", "response.content #byte olarak" ] }, { "cell_type": "code", "execution_count": 251, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:50:02.611257Z", "start_time": "2021-04-12T11:50:02.604275Z" }, "id": "CC-Ru5WBNP19", "outputId": "45bf2b51-72e2-40b7-b3f8-6c69ce234f2e", "colab": { "base_uri": "https://localhost:8080/", "height": 53 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'{\\n \"args\": {}, \\n \"headers\": {\\n \"Accept\": \"*/*\", \\n \"Accept-Encoding\": \"gzip, deflate\", \\n \"Host\": \"httpbin.org\", \\n \"User-Agent\": \"python-requests/2.32.3\", \\n \"X-Amzn-Trace-Id\": \"Root=1-66f03742-6923173002866a3c50f6dfc5\"\\n }, \\n \"origin\": \"34.16.168.234\", \\n \"url\": \"https://httpbin.org/get\"\\n}\\n'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 251 } ], "source": [ "response.text #string olarak" ] }, { "cell_type": "code", "execution_count": 252, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:50:07.692493Z", "start_time": "2021-04-12T11:50:07.689491Z" }, "id": "dQuY_FaMNP19", "outputId": "69ef30ae-edcb-41db-9ed1-876230c534b1", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 252 } ], "source": [ "response.raw" ] }, { "cell_type": "markdown", "metadata": { "id": "aT_D0icCNP19" }, "source": [ "Böyle çok karışık oldu, bunu json olarak okuyalım. ama tabi önce bunun son versiyonuna tekrar bi get atalım." ] }, { "cell_type": "code", "execution_count": 253, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:50:45.445755Z", "start_time": "2021-04-12T11:50:45.165506Z" }, "id": "w_4RI0kZNP1-", "outputId": "805a936b-4645-4d61-ae0c-ead5c614035a", "colab": { "base_uri": "https://localhost:8080/", "height": 53 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'{\\n \"args\": {}, \\n \"headers\": {\\n \"Accept\": \"*/*\", \\n \"Accept-Encoding\": \"gzip, deflate\", \\n \"Host\": \"httpbin.org\", \\n \"User-Agent\": \"python-requests/2.32.3\", \\n \"X-Amzn-Trace-Id\": \"Root=1-66f03743-514f57731ffeb7ce34129485\"\\n }, \\n \"origin\": \"34.16.168.234\", \\n \"url\": \"https://httpbin.org/get\"\\n}\\n'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 253 } ], "source": [ "#hala biraz okunaklı değil gibi\n", "response = requests.get(httpget3)\n", "response.text" ] }, { "cell_type": "code", "execution_count": 254, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:50:31.769676Z", "start_time": "2021-04-12T11:50:31.761693Z" }, "id": "WQ895eaFNP1-", "outputId": "0ae60c50-7a8e-4edd-f5c1-0c25a66aea06", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{'args': {},\n", " 'headers': {'Accept': '*/*',\n", " 'Accept-Encoding': 'gzip, deflate',\n", " 'Host': 'httpbin.org',\n", " 'User-Agent': 'python-requests/2.32.3',\n", " 'X-Amzn-Trace-Id': 'Root=1-66f03743-514f57731ffeb7ce34129485'},\n", " 'origin': '34.16.168.234',\n", " 'url': 'https://httpbin.org/get'}" ] }, "metadata": {}, "execution_count": 254 } ], "source": [ "json.loads(response.text)" ] }, { "cell_type": "code", "execution_count": 255, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:49:39.489580Z", "start_time": "2021-04-12T11:49:39.480603Z" }, "id": "K_c3PGEENP1-", "outputId": "0bf71ddb-0530-401e-86d2-0d70fa5ead3f", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{'args': {},\n", " 'headers': {'Accept': '*/*',\n", " 'Accept-Encoding': 'gzip, deflate',\n", " 'Host': 'httpbin.org',\n", " 'User-Agent': 'python-requests/2.32.3',\n", " 'X-Amzn-Trace-Id': 'Root=1-66f03743-514f57731ffeb7ce34129485'},\n", " 'origin': '34.16.168.234',\n", " 'url': 'https://httpbin.org/get'}" ] }, "metadata": {}, "execution_count": 255 } ], "source": [ "#veya responseun json metopdunu kullanabiliriz\n", "response.json()" ] }, { "cell_type": "markdown", "metadata": { "id": "oQpsp8BiNP1-" }, "source": [ "It should be noted that the success of the call to r.json() does not indicate the success of the response. Some servers may return a JSON object in a failed response (e.g. error details with HTTP 500). Such JSON will be decoded and returned. To check that a request is successful, use r.raise_for_status() or check r.status_code is what you expect." ] }, { "cell_type": "code", "execution_count": 256, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:51:01.521114Z", "start_time": "2021-04-12T11:51:01.517158Z" }, "id": "Y-yvVvIFNP1-", "outputId": "2f259fb0-8286-4ec4-aec1-c225ec78b0bf", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "200" ] }, "metadata": {}, "execution_count": 256 } ], "source": [ "response.raise_for_status()\n", "response.status_code" ] }, { "cell_type": "code", "execution_count": 257, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:51:09.536268Z", "start_time": "2021-04-12T11:51:09.531280Z" }, "id": "MRIBCQXlNP1_", "outputId": "d42a67b4-76b0-44d6-c3b4-e00c1f39f527", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{'Date': 'Sun, 22 Sep 2024 15:26:59 GMT',\n", " 'Content-Type': 'application/json',\n", " 'Content-Length': '307',\n", " 'Connection': 'keep-alive',\n", " 'Server': 'gunicorn/19.9.0',\n", " 'Access-Control-Allow-Origin': '*',\n", " 'Access-Control-Allow-Credentials': 'true'}" ] }, "metadata": {}, "execution_count": 257 } ], "source": [ "dict(response.headers)" ] }, { "cell_type": "code", "execution_count": 258, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:51:15.329872Z", "start_time": "2021-04-12T11:51:15.323889Z" }, "id": "pCFUpP0ONP1_", "outputId": "90b9edf9-e069-43e3-a532-d0f0f3d8d795", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'application/json'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 258 } ], "source": [ "response.headers['Content-Type']" ] }, { "cell_type": "markdown", "metadata": { "id": "OZXIKvJiNP1_" }, "source": [ "### QueryString parameters" ] }, { "cell_type": "code", "execution_count": 259, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:51:35.981224Z", "start_time": "2021-04-12T11:51:34.739424Z" }, "id": "A8MuEWfwNP1_", "outputId": "2b4745f4-53d3-44d2-a5bc-4a45db5a2750", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Repository name: secrules-language-evaluation\n", "Repository description: Set of Python scripts to perform SecRules language evaluation on a given http request.\n", "https://api.github.com/search/repositories?q=requests%2Blanguage%3Apython\n" ] } ], "source": [ "# Search GitHub's repositories for requests\n", "response = requests.get(\n", " 'https://api.github.com/search/repositories',\n", " params={'q': 'requests+language:python'},\n", ")\n", "\n", "# Inspect some attributes of the `requests` repository\n", "json_response = response.json()\n", "repository = json_response['items'][0]\n", "print(f'Repository name: {repository[\"name\"]}') # Python 3.6+\n", "print(f'Repository description: {repository[\"description\"]}') # Python 3.6+\n", "print(response.url)" ] }, { "cell_type": "code", "execution_count": 260, "metadata": { "ExecuteTime": { "end_time": "2021-04-12T11:51:36.220773Z", "start_time": "2021-04-12T11:51:35.991157Z" }, "id": "gji0Xwf1NP1_", "outputId": "2920a2bd-235f-4cbf-ba34-f42f7a03f573", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "https://www.excelinefendisi.com/httpapiservice/ResponseveRequestTarget.aspx?Anakonu=VBAMakro&Altkonu=Temeller\n" ] } ], "source": [ "response = requests.get(\n", " 'https://www.excelinefendisi.com/httpapiservice/ResponseveRequestTarget.aspx',\n", " params={'Anakonu':'VBAMakro', 'Altkonu':'Temeller'},\n", ")\n", "\n", "print(response.url)" ] }, { "cell_type": "code", "execution_count": 261, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T11:54:43.262529Z", "start_time": "2021-04-11T11:54:43.257543Z" }, "id": "5irgpaj_NP2A", "outputId": "2c6f96ae-621c-4582-82d8-f89887510002", "colab": { "base_uri": "https://localhost:8080/", "height": 125 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n

Genel bilgier

\\r\\n VBAMakro anakousu ve Temeller altkonusu altında toplam 5 adet konu var

\\r\\n
\\r\\n
\\r\\n

Data bölgesi

\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 261 } ], "source": [ "response.text" ] }, { "cell_type": "code", "execution_count": 262, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T11:48:29.128562Z", "start_time": "2021-04-11T11:48:28.375577Z" }, "id": "wedIz7JuNP2A" }, "outputs": [], "source": [ "payload = {'key1': 'value1', 'key2': 'value2'}\n", "r = requests.get('https://httpbin.org/get', params=payload)" ] }, { "cell_type": "markdown", "metadata": { "id": "Zg-_6jfqNP2A" }, "source": [ "### Headers" ] }, { "cell_type": "code", "execution_count": 263, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T11:49:45.766142Z", "start_time": "2021-04-11T11:49:45.761157Z" }, "id": "sevAAWy_NP2A", "outputId": "13cd6f19-cfd0-4a5b-8918-db616b4d6fa4", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{'Date': 'Sun, 22 Sep 2024 15:27:02 GMT', 'Content-Type': 'application/json', 'Content-Length': '378', 'Connection': 'keep-alive', 'Server': 'gunicorn/19.9.0', 'Access-Control-Allow-Origin': '*', 'Access-Control-Allow-Credentials': 'true'}" ] }, "metadata": {}, "execution_count": 263 } ], "source": [ "r.headers" ] }, { "cell_type": "code", "execution_count": 264, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:30:34.969712Z", "start_time": "2021-04-11T15:30:33.026070Z" }, "id": "Kj9A2F0lNP2A", "outputId": "a096b30e-00fb-4753-d627-de922d43acef", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Text matches: [{'object_url': 'https://api.github.com/repositories/33210074', 'object_type': 'Repository', 'property': 'description', 'fragment': 'Set of Python scripts to perform SecRules language evaluation on a given http request.', 'matches': [{'text': 'Python', 'indices': [7, 13]}, {'text': 'language', 'indices': [42, 50]}, {'text': 'request', 'indices': [78, 85]}]}]\n" ] } ], "source": [ "#custimize header\n", "response = requests.get(\n", " 'https://api.github.com/search/repositories',\n", " params={'q': 'requests+language:python'},\n", " headers={'Accept': 'application/vnd.github.v3.text-match+json'},\n", ")\n", "\n", "# View the new `text-matches` array which provides information\n", "# about your search term within the results\n", "json_response = response.json()\n", "repository = json_response['items'][0]\n", "print(f'Text matches: {repository[\"text_matches\"]}')" ] }, { "cell_type": "code", "execution_count": 265, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:32:08.420664Z", "start_time": "2021-04-11T15:32:04.440680Z" }, "id": "J8llQRkZNP2B", "outputId": "6be386b6-0ab9-4389-9880-e13c803bad38", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 265 }, { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 265 }, { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 265 }, { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 265 }, { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 265 }, { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 265 } ], "source": [ "requests.post('https://httpbin.org/post', data={'key':'value'})\n", "requests.put('https://httpbin.org/put', data={'key':'value'})\n", "requests.delete('https://httpbin.org/delete')\n", "requests.head('https://httpbin.org/get')\n", "requests.patch('https://httpbin.org/patch', data={'key':'value'})\n", "requests.options('https://httpbin.org/get')" ] }, { "cell_type": "code", "execution_count": 266, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:38:34.572083Z", "start_time": "2021-04-11T15:38:33.892213Z" }, "id": "d5dkc-WuNP2B", "outputId": "7ff58a19-b1b7-43b7-b015-38caa766d0d4", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'application/json'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 266 } ], "source": [ "response = requests.head('https://httpbin.org/get')\n", "response.headers['Content-Type']" ] }, { "cell_type": "code", "execution_count": 267, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:38:35.242197Z", "start_time": "2021-04-11T15:38:34.581059Z" }, "id": "WYFFyWK5NP2B", "outputId": "c28564c0-9cfa-41be-c4ae-50360092a752", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "{}" ] }, "metadata": {}, "execution_count": 267 } ], "source": [ "response = requests.delete('https://httpbin.org/delete')\n", "json_response = response.json()\n", "json_response['args']" ] }, { "cell_type": "code", "execution_count": 267, "metadata": { "id": "uBIXUnWINP2B" }, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": { "id": "JBq0Jus3NP2B" }, "source": [ "According to the HTTP specification, POST, PUT, and the less common PATCH requests pass their data through the message body rather than through parameters in the query string." ] }, { "cell_type": "code", "execution_count": 268, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:42:05.930360Z", "start_time": "2021-04-11T15:42:05.214746Z" }, "id": "TEJ5QWWINP2B", "outputId": "c5b8451b-8960-4af7-ab43-7156f92fa0e2", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 268 } ], "source": [ "requests.post('https://httpbin.org/post', data={'key':'value'}) #veya data=[('key', 'value')]" ] }, { "cell_type": "code", "execution_count": 269, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:42:05.930360Z", "start_time": "2021-04-11T15:42:05.214746Z" }, "id": "mzxTUWMyNP2C", "outputId": "061fdd6b-ef46-42ad-ed26-cbf287da833f", "colab": { "base_uri": "https://localhost:8080/", "height": 53 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'{\"key\": \"value\"}'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 269 }, { "output_type": "execute_result", "data": { "text/plain": [ "'application/json'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 269 } ], "source": [ "response = requests.post('https://httpbin.org/post', json={'key':'value'})\n", "json_response = response.json()\n", "json_response['data']\n", "json_response['headers']['Content-Type']" ] }, { "cell_type": "code", "execution_count": 270, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:43:12.381811Z", "start_time": "2021-04-11T15:43:10.781580Z" }, "id": "HkoeyFP8NP2C", "outputId": "a44efcf5-d338-4e21-a047-706fa48e8471", "colab": { "base_uri": "https://localhost:8080/", "height": 71 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'application/json'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 270 }, { "output_type": "execute_result", "data": { "text/plain": [ "'https://httpbin.org/post'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 270 }, { "output_type": "execute_result", "data": { "text/plain": [ "b'{\"key\": \"value\"}'" ] }, "metadata": {}, "execution_count": 270 } ], "source": [ "response = requests.post('https://httpbin.org/post', json={'key':'value'})\n", "response.request.headers['Content-Type']\n", "response.request.url\n", "response.request.body" ] }, { "cell_type": "code", "execution_count": 271, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:44:21.560506Z", "start_time": "2021-04-11T15:44:21.551487Z" }, "id": "WkwQy86INP2C", "outputId": "cb742d6b-a725-47a0-cbc8-5a4780d4d3fd", "colab": { "base_uri": "https://localhost:8080/", "height": 125 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'https://httpbin.org/post'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 271 }, { "output_type": "execute_result", "data": { "text/plain": [ "{'Date': 'Sun, 22 Sep 2024 15:27:06 GMT', 'Content-Type': 'application/json', 'Content-Length': '481', 'Connection': 'keep-alive', 'Server': 'gunicorn/19.9.0', 'Access-Control-Allow-Origin': '*', 'Access-Control-Allow-Credentials': 'true'}" ] }, "metadata": {}, "execution_count": 271 }, { "output_type": "execute_result", "data": { "text/plain": [ "'https://httpbin.org/post'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 271 }, { "output_type": "execute_result", "data": { "text/plain": [ "{'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Length': '16', 'Content-Type': 'application/json'}" ] }, "metadata": {}, "execution_count": 271 } ], "source": [ "response.url\n", "response.headers\n", "response.request.url\n", "response.request.headers" ] }, { "cell_type": "code", "execution_count": 272, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T15:46:11.366531Z", "start_time": "2021-04-11T15:46:07.443303Z" }, "id": "Ar-7Lm2INP2C", "outputId": "66148973-0f66-4780-9b7c-134a196d23e0", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "··········\n" ] }, { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 272 } ], "source": [ "#authentication\n", "from getpass import getpass\n", "requests.get('https://api.github.com/user', auth=('username', getpass()))" ] }, { "cell_type": "markdown", "metadata": { "id": "UEBYM_WtNP2C" }, "source": [ "### webserive" ] }, { "cell_type": "markdown", "metadata": { "id": "TxzHfG0uNP2D" }, "source": [ "## BeautifulSoup" ] }, { "cell_type": "markdown", "metadata": { "id": "vx_97dK0NP2D" }, "source": [ "https://realpython.com/beautiful-soup-web-scraper-python/" ] }, { "cell_type": "code", "execution_count": 273, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:36:30.137338Z", "start_time": "2021-05-15T15:36:28.992174Z" }, "id": "Si95rGouNP2D" }, "outputs": [], "source": [ "URL = 'https://www.monster.com/jobs/search/?q=Software-Developer&where=Australia'\n", "page = requests.get(URL)" ] }, { "cell_type": "code", "execution_count": 274, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:36:31.477395Z", "start_time": "2021-05-15T15:36:30.887143Z" }, "id": "GJ-K5HruNP2D" }, "outputs": [], "source": [ "import requests\n", "from bs4 import BeautifulSoup\n", "\n", "URL = 'https://www.excelinefendisi.com/Konular/Excel/Giris_PratikKisayollar.aspx'\n", "page = requests.get(URL)\n", "\n", "soup = BeautifulSoup(page.content, 'html.parser')" ] }, { "cell_type": "code", "execution_count": 275, "metadata": { "ExecuteTime": { "end_time": "2021-05-15T15:36:33.839511Z", "start_time": "2021-05-15T15:36:33.831531Z" }, "scrolled": true, "id": "K-NWhchbNP2E", "outputId": "cb6ba55a-a6af-4558-ff6d-9aa2b4f646b1", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "
AmaçKısayol
Sayfalar arasında dolaşmakCTRL + PgUp/PgDn
Bugünün Tarihini yazmakCTRL + SHIFT +,
Tüm açık dosyalarda calculation yapmakF9
Seçili kısmın değerini hesaplayıp göstermekHücre içindeki formül seçilip F9
Aktif sayfada calculation yapmakSHIFT+F9
Sadece belli range için calculation yapmakVBA ile yapılır. Burdan bakın.
Bulunduğun hücrenin CurrentRegion'ını seçmeCTRL+ A
Bulunduğun hücreden CurrentRegion'ın uç noktlarına gitmekCTRL+ Ok tuşları
Bulunduğun hücreden itibaren belli bir yöne doğru seçim yapmakSHIFT+Ok tuşları
Bulunduğun hücreden itibaren CurrentRegion bir ucuna doğru toplu seçim yapmakCTRL+SHIFT+Ok tuşları
Bulunduğun hücreden CurrentRegion'ın Sağ Aşağı uç noktlasına gitmekCTRL+END
Bulunduğun hücreden CurrentRegion'ın Sağ Aşağı uç noktlasına kadar seçmekCTRL+SHIFT+END
Bulunduğun hücreden A1 hücresine kadar olan alanı(sol yukarı) seçmekCTRL+SHIFT+HOME
Bir hücre içinde veri girerken, aynı hücre içinde yeni bir satır açıp oradan devam etmekALT+ENTER
Veri/Formül girişi yaptığınız hücrede alt hücreye geçmeden giriş tamamlamak CTRL+ENTER
Ekranda bir sayfa sağa kaymak.ALT+PGE DOWN
AutoFilter'ı aktif/pasif hale getirmekCTRL+SHIFT+L
Bulunduğunuz hücrenin satır ve sütununa aynı anda freeze uygulamak/kaldırmakAlt+W+FF
VBA editörünü açmakAlt+F11
Ribbonu küçültüp/büyütmekCTRL+F1
Üst hücrelerdeki tüm rakamların toplamını almakALT+=
Flash Fill uygulamakCTRL+E
Sadece görünen hücreleri seçmekALT+;
\n", "\n" ] } ], "source": [ "results = soup.find_all(class_='alterantelitable')\n", "for r in results:\n", " print(r, end='\\n'*2)" ] }, { "cell_type": "markdown", "metadata": { "id": "51f4k7lrNP2E" }, "source": [ "Gereksiz elementlerden ve taglerden kurtulalım" ] }, { "cell_type": "code", "execution_count": 276, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T16:29:28.266800Z", "start_time": "2021-04-11T16:29:28.257824Z" }, "scrolled": true, "id": "pYqhdq3DNP2E", "outputId": "226501c1-8de7-4801-cac5-05b138ffbb53", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Sayfalar arasında dolaşmak\n", "CTRL + PgUp/PgDn\n", "Bugünün Tarihini yazmak\n", "CTRL + SHIFT +, \n", "Tüm açık dosyalarda calculation yapmak\n", "F9\n", "Seçili kısmın değerini hesaplayıp göstermek\n", "Hücre içindeki formül seçilip F9\n", "Aktif sayfada calculation yapmak\n", "SHIFT+F9\n", "Sadece belli range için calculation yapmak\n", "VBA ile yapılır. Burdan bakın.\n", "Bulunduğun hücrenin CurrentRegion'ını seçme\n", "CTRL+ A\n", "Bulunduğun hücreden CurrentRegion'ın uç noktlarına gitmek\n", "CTRL+ Ok tuşları\n", "Bulunduğun hücreden itibaren belli bir yöne doğru seçim yapmak\n", "SHIFT+Ok tuşları\n", "Bulunduğun hücreden itibaren CurrentRegion bir ucuna doğru toplu seçim yapmak\n", "CTRL+SHIFT+Ok tuşları\n", "Bulunduğun hücreden CurrentRegion'ın Sağ Aşağı uç noktlasına gitmek\n", "CTRL+END\n", "Bulunduğun hücreden CurrentRegion'ın Sağ Aşağı uç noktlasına kadar seçmek\n", "CTRL+SHIFT+END\n", "Bulunduğun hücreden A1 hücresine kadar olan alanı(sol yukarı) seçmek\n", "CTRL+SHIFT+HOME\n", "Bir hücre içinde veri girerken, aynı hücre içinde yeni bir satır açıp oradan devam etmek\n", "ALT+ENTER\n", "Veri/Formül girişi yaptığınız hücrede alt hücreye geçmeden giriş tamamlamak \n", "CTRL+ENTER\n", " Ekranda bir sayfa sağa kaymak.\n", "ALT+PGE DOWN\n", "AutoFilter'ı aktif/pasif hale getirmek\n", "CTRL+SHIFT+L\n", "Bulunduğunuz hücrenin satır ve sütununa aynı anda freeze uygulamak/kaldırmak\n", "Alt+W+FF\n", "VBA editörünü açmak\n", "Alt+F11\n", "Ribbonu küçültüp/büyütmek\n", "CTRL+F1\n", "Üst hücrelerdeki tüm rakamların toplamını almak\n", "ALT+=\n", "Flash Fill uygulamak\n", "CTRL+E\n", "Sadece görünen hücreleri seçmek\n", "ALT+;\n" ] } ], "source": [ "results = soup.find_all(class_='alterantelitable')\n", "for r in results:\n", " tds=r.find_all(\"td\")\n", " for td in tds:\n", " print(td.text)" ] }, { "cell_type": "markdown", "metadata": { "id": "8R_PjPfHNP2E" }, "source": [ "İşlemle ilgili kısayolu altalta değil de yanyana yazmasını sağlayalım," ] }, { "cell_type": "code", "execution_count": 277, "metadata": { "ExecuteTime": { "end_time": "2021-04-11T16:43:05.446075Z", "start_time": "2021-04-11T16:43:05.431291Z" }, "id": "csDNZGeHNP2F", "outputId": "de4eefe6-b523-4db6-e90d-d0d269f85f8b", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "Sayfalar arasında dolaşmak : CTRL + PgUp/PgDn\n", "Bugünün Tarihini yazmak : CTRL + SHIFT +, \n", "Tüm açık dosyalarda calculation yapmak : F9\n", "Seçili kısmın değerini hesaplayıp göstermek : Hücre içindeki formül seçilip F9\n", "Aktif sayfada calculation yapmak : SHIFT+F9\n", "Sadece belli range için calculation yapmak : VBA ile yapılır. Burdan bakın.\n", "Bulunduğun hücrenin CurrentRegion'ını seçme : CTRL+ A\n", "Bulunduğun hücreden CurrentRegion'ın uç noktlarına gitmek : CTRL+ Ok tuşları\n", "Bulunduğun hücreden itibaren belli bir yöne doğru seçim yapmak : SHIFT+Ok tuşları\n", "Bulunduğun hücreden itibaren CurrentRegion bir ucuna doğru toplu seçim yapmak : CTRL+SHIFT+Ok tuşları\n", "Bulunduğun hücreden CurrentRegion'ın Sağ Aşağı uç noktlasına gitmek : CTRL+END\n", "Bulunduğun hücreden CurrentRegion'ın Sağ Aşağı uç noktlasına kadar seçmek : CTRL+SHIFT+END\n", "Bulunduğun hücreden A1 hücresine kadar olan alanı(sol yukarı) seçmek : CTRL+SHIFT+HOME\n", "Bir hücre içinde veri girerken, aynı hücre içinde yeni bir satır açıp oradan devam etmek : ALT+ENTER\n", "Veri/Formül girişi yaptığınız hücrede alt hücreye geçmeden giriş tamamlamak : CTRL+ENTER\n", " Ekranda bir sayfa sağa kaymak. : ALT+PGE DOWN\n", "AutoFilter'ı aktif/pasif hale getirmek : CTRL+SHIFT+L\n", "Bulunduğunuz hücrenin satır ve sütununa aynı anda freeze uygulamak/kaldırmak : Alt+W+FF\n", "VBA editörünü açmak : Alt+F11\n", "Ribbonu küçültüp/büyütmek : CTRL+F1\n", "Üst hücrelerdeki tüm rakamların toplamını almak : ALT+=\n", "Flash Fill uygulamak : CTRL+E\n", "Sadece görünen hücreleri seçmek : ALT+;\n" ] } ], "source": [ "results = soup.find_all(class_='alterantelitable')\n", "for r in results:\n", " trs=r.find_all(\"tr\")\n", " for tr in trs:\n", " td1=tr.select(\"td\")[0] #tr.find(\"td\") de olurdu ama aşağıdakiyle bütünlük olması adına ikisini de select ile yaptık\n", " td2=tr.select(\"td\")[1]\n", " print(td1.text,\":\",td2.text)" ] }, { "cell_type": "markdown", "metadata": { "id": "UAMBIdNvNP2G" }, "source": [ "Bunun bir de MechanicalSoup versiyonu var, onda websitelerindeki formları da otomatik doldurma işlemi yaptırabiliyorsunuz." ] }, { "cell_type": "markdown", "metadata": { "id": "MhE55BdvNP2G" }, "source": [ "## Logging" ] }, { "cell_type": "markdown", "metadata": { "id": "bka1Z3k2NP2G" }, "source": [ "Programınızı test ederken print değil bunu kullanmanız önerilir." ] }, { "cell_type": "code", "execution_count": 278, "metadata": { "ExecuteTime": { "end_time": "2021-05-12T20:51:08.220308Z", "start_time": "2021-05-12T20:51:08.214322Z" }, "scrolled": true, "id": "5O9wEIgdNP2G", "outputId": "f041b6b9-13a9-48f0-9ea3-601527e97c13", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "WARNING:root:This is a warning message\n", "ERROR:root:This is an error message\n", "CRITICAL:root:This is a critical message\n" ] } ], "source": [ "import logging\n", "\n", "logging.debug('This is a debug message')\n", "logging.info('This is an info message')\n", "#by default, the logging module logs the messages with a severity level of WARNING or above\n", "logging.warning('This is a warning message')\n", "logging.error('This is an error message')\n", "logging.critical('This is a critical message')" ] }, { "cell_type": "markdown", "metadata": { "id": "xk3DLOV3NP2G" }, "source": [ "root= default logger" ] }, { "cell_type": "code", "execution_count": 279, "metadata": { "ExecuteTime": { "end_time": "2021-05-12T20:55:46.385664Z", "start_time": "2021-05-12T20:55:46.381676Z" }, "id": "mg7IqQ4ONP2G", "outputId": "be829d2c-5910-4b89-c11c-833dc01ecd5a", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "DEBUG:root:This will get logged\n" ] } ], "source": [ "logging.basicConfig(level=logging.DEBUG,force=True) #son parametre gerekli. Detay için: https://stackoverflow.com/questions/30861524/logging-basicconfig-not-creating-log-file-when-i-run-in-pycharm/42210221\n", "logging.debug('This will get logged')" ] }, { "cell_type": "code", "execution_count": 280, "metadata": { "ExecuteTime": { "end_time": "2021-05-12T20:56:20.598673Z", "start_time": "2021-05-12T20:56:20.592689Z" }, "id": "wfoAAVXPNP2G" }, "outputs": [], "source": [ "logging.basicConfig(filename='app.log', filemode='w', format='%(name)s - %(levelname)s - %(message)s',force=True)\n", "logging.warning('This will get logged to a file')" ] }, { "cell_type": "code", "execution_count": 281, "metadata": { "ExecuteTime": { "end_time": "2021-05-12T21:01:25.865412Z", "start_time": "2021-05-12T21:01:25.861458Z" }, "id": "4Pr6c5K-NP2G", "outputId": "669451d9-de35-47b3-db05-3cc28263ecab", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "root - INFO - 2024-09-22 15:27:21,768 - Admin logged in\n" ] } ], "source": [ "logging.basicConfig(format='%(name)s - %(levelname)s - %(asctime)s - %(message)s', level=logging.INFO,force=True)\n", "logging.info('Admin logged in')" ] }, { "cell_type": "code", "execution_count": 282, "metadata": { "ExecuteTime": { "end_time": "2021-05-12T21:01:28.566129Z", "start_time": "2021-05-12T21:01:28.561176Z" }, "id": "7ix2oUooNP2H", "outputId": "680775a0-88d8-48ea-a7d3-2ca323bbf378", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "root - ERROR - 2024-09-22 15:27:21,801 - John raised an error\n" ] } ], "source": [ "name = 'John'\n", "logging.error(f'{name} raised an error')" ] }, { "cell_type": "code", "execution_count": 283, "metadata": { "ExecuteTime": { "end_time": "2021-05-12T21:02:03.896954Z", "start_time": "2021-05-12T21:02:03.892964Z" }, "id": "e8kdrYAINP2H", "outputId": "84511400-71fb-4713-cd41-66df36e571e3", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "root - ERROR - 2024-09-22 15:27:21,848 - Exception occurred\n", "Traceback (most recent call last):\n", " File \"\", line 5, in \n", " c = a / b\n", "ZeroDivisionError: division by zero\n" ] } ], "source": [ "a = 5\n", "b = 0\n", "\n", "try:\n", " c = a / b\n", "except Exception as e:\n", " logging.error(\"Exception occurred\", exc_info=True)" ] }, { "cell_type": "markdown", "metadata": { "id": "LshsfDgTNP2H" }, "source": [ "## tqdm" ] }, { "cell_type": "markdown", "metadata": { "id": "DJtLjr4tNP2H" }, "source": [ "Döngüsel işlemlerde progressbar sağlar" ] }, { "cell_type": "code", "execution_count": 284, "metadata": { "id": "KrYPCMN9NP2H", "outputId": "1761a60f-4bc2-4b90-a2bb-e356dd9132fd", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "100%|██████████| 10/10 [00:01<00:00, 9.61it/s]\n" ] } ], "source": [ "from tqdm import tqdm, trange\n", "from time import sleep\n", "\n", "for i in tqdm(range(10)):\n", " sleep(.1)" ] }, { "cell_type": "code", "execution_count": 285, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "UKdGnJCmNP2I", "outputId": "4dc2bbd6-2e97-4188-ceb3-27059532243d" }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "100%|██████████| 100/100 [00:01<00:00, 96.83it/s]\n" ] } ], "source": [ "# Simple loop\n", "for i in range(100):\n", " pass\n", "\n", "# Loop with a progress bar\n", "for i in trange(100):\n", " time.sleep(0.01)" ] }, { "cell_type": "code", "execution_count": 286, "metadata": { "colab": { "referenced_widgets": [ "751edc7876624c858be3920a656bbe5a", "a17d5706940d471c8def62d24b380451", "94759083162b4ba7882beb31f5f5c0e6", "da19b67ccfca40f0ac6fea0079279b45", "451f673b411e45c89ba06581e24f3632", "34289f2781b94924ab52dcc7accc4f9b", "1178361d7b984b039fd0e5ee6a569adb", "125bc33900574ed692c44040871f04d0", "c26eb70f93b248e2b78df67a5b6ccc65", "13308604b83b4ff881bf2e86f199a654", "286b1c469c4f48c9b4dca098d506e0e2", "4b45e53206ac4335ad64c1bc76cf0a54", "94b5dcb00309447db4caf1ca5f2bca6c", "f34d953ef0f04222800959bad565983a", "4a35b3bf482b483bbe7f3979968b2b57", "f21bf8ef6c2543e5b9bd3a2006f37d99", "898d07425ae6424d9b373bcb23388625", "2ce64cb4ef464074a58d8d3985b7a4c3", "a30f9a14b37949aea2fe0577940e22d3", "803c924d944242399095d29937f7e046", "bd81728b56694c7493e07276209917a8", "e1a40e5aab3f40ebbb01cd40c1994a8b", "55a59a782aa84a98a6ae9a131707e7e4", "a2adb592ff3245869a0d6379148a97fa", "d9fb51af123045bfb01c0ca4ff71aadf", "f057770d640d4d768887b58b24a05698", "b2b1f12e421249369d42dee4ee11ff55", "c017e47d80f04575872ee21fa7dc9271", "1f31528beea8479db1929519dc36ebe0", "ff25dde586244614852fb29ffd51dac9", "2ad95d0a26034b62ad7a0941045a8bd6", "5dc1487f2b6a4a339d103355b6209569", "2193d83b7019419c86f9915866b79247", "a57d90da18644950b9ffc8517fe1df7b", "da5f50d542c14d8f898c9f76abd9709d", "8e86a15ad03845ed93fc85c7b82487d4", "0aa16e4c1d1d4059841e36d8b325971f", "9fd3dc999c6d4270a9ecfe2d8e8f5e1d", "6ec9be16d0354a8d87c177f2f68c49da", "10a3331d6fec4345a45b8f8f9d0a8146", "f125a24c6cf347a3b296a2906556be7a", "e618cb21d1d6458ca0374e8618dd4ca8", "2ddf420ed3dc4d429495f5ba7f922956", "1516a50c3d4342f693aefe40460d6dd2" ], "base_uri": "https://localhost:8080/", "height": 145 }, "id": "wgi0kDEPNP2J", "outputId": "a1d4a42d-6796-4150-e40e-65b47545c015" }, "outputs": [ { "output_type": "display_data", "data": { "text/plain": [ "1st loop: 0%| | 0/3 [00:00Görsel bu sayfadan alınmıştır

\"\"\")\n", " \n", "def pythonSomeInfo():\n", " print(\"system packages folder:\",sys.prefix, end=\"\\n\\n\")\n", " print(\"pip install folder:\",site.getsitepackages(), end=\"\\n\\n\") \n", " print(\"python version:\", sys.version, end=\"\\n\\n\")\n", " print(\"executables location:\",sys.executable, end=\"\\n\\n\")\n", " print(\"pip version:\", os.popen('pip version').read(), end=\"\\n\\n\")\n", " pathes= sys.path\n", " print(\"Python pathes\")\n", " for p in pathes:\n", " print(p)\n", "\n", "\n", "def showMemoryUsage():\n", " dict_={}\n", " global_vars = list(globals().items())\n", " for var, obj in global_vars:\n", " if not var.startswith('_'):\n", " dict_[var]=sys.getsizeof(obj)\n", " \n", " final={k: v for k, v in sorted(dict_.items(), key=lambda item: item[1],reverse=True)} \n", " print(final)\n", " \n", "def readfile(path,enc='cp1254'):\n", " with io.open(path, \"r\", encoding=enc) as f:\n", " return f.read()\n", "\n", "def getFirstItemFromDictionary(dict_):\n", " return next(iter(dict_)),next(iter(dict_.values()))\n", " \n", "\n", "\n", "def removeItemsFromList(self,list2,inplace=True): \n", " \"\"\"\n", " Extension method for list type. Removes items from list2 from list1.\n", " First, forbiddenfruit must be installed via https://pypi.org/project/forbiddenfruit/\n", " \"\"\" \n", " if inplace:\n", " for x in set(list2):\n", " self.remove(x)\n", " return self\n", " else:\n", " temp=self.copy()\n", " for x in set(list2):\n", " temp.remove(x)\n", " return temp\n", " \n", "curse(list, \"removeItemsFromList\", removeItemsFromList)\n", "\n", "\n", "\n", "\n", "\n", "\n", "----\n" ] }, { "output_type": "execute_result", "data": { "text/plain": [ "0" ] }, "metadata": {}, "execution_count": 294 }, { "output_type": "stream", "name": "stdout", "text": [ "fr\n" ] } ], "source": [ "#oku\n", "#import io #normalde bu satıra gerek yok, open=io.open için bi alias\n", "dosya = io.open(\"pythonutility.py\", \"r\") #yine bunda da başta io yazmazdık normalde ama os'nin open'ından ayırmak için ekledik\n", "print(dosya.readline(1))\n", "print(\"----\")\n", "print(dosya.read()) #ilk satırı okuduğumuz için ikinci satırdan okumaya devam ediyor\n", "print(\"----\")\n", "dosya.seek(0) #başa konumlanalım tekrar\n", "print(dosya.readline(2)) #baştan ilk 2 karakter" ] }, { "cell_type": "code", "execution_count": 295, "metadata": { "id": "NYJPrI_9NP2M", "outputId": "cda78192-025c-4574-baa5-472ee9fc3b99", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "0" ] }, "metadata": {}, "execution_count": 295 }, { "output_type": "stream", "name": "stdout", "text": [ "1-from __future__ import print_function\n", "2-import inspect\n", "3-import os, sys, site\n", "4-import functools\n", "5-import time\n", "6-from forbiddenfruit import curse\n", "7-\n", "8-try:\n", "9- import __builtin__\n", "10-except ImportError:\n", "11- import builtins as __builtin__\n", "12-\n", "13-# *************************************************************************************************************\n", "14-#Module level methods\n", "15-\n", "16- \n", "17-def lineno():\n", "18- previous_frame = inspect.currentframe().f_back.f_back\n", "19- (filename, line_number, function_name, lines, index) = inspect.getframeinfo(previous_frame)\n", "20- return (line_number, lines)\n", "21- #return inspect.currentframe().f_back.f_back.f_lineno, str(inspect.currentframe().f_back)\n", "22-\n", "23-def printy(*args, **kwargs):\n", "24- print(lineno(),\"\\n----------\")\n", "25- print(*args, **kwargs)\n", "26- print(\" \",end=\"\\n\")\n", "27-\n", "28-\n", "29-def timeElapse(func):\n", "30- \"\"\"\n", "31- usage:\n", "32- @timeElapse\n", "33- def somefunc():\n", "34- ...\n", "35- ...\n", "36-\n", "37- somefunc()\n", "38- \"\"\"\n", "39- @functools.wraps(func)\n", "40- def wrapper(*args,**kwargs):\n", "41- start=time.time()\n", "42- value=func(*args,**kwargs)\n", "43- func()\n", "44- finito=time.time()\n", "45- print(\"Time elapsed:{}\".format(finito-start))\n", "46- return value\n", "47- return wrapper \n", "48-\n", "49-\n", "50-def multioutput(type=\"all\"):\n", "51- from IPython.core.interactiveshell import InteractiveShell\n", "52- InteractiveShell.ast_node_interactivity = type\n", "53- \n", "54-def scriptforReload():\n", "55- print(\"\"\"\n", "56- %load_ext autoreload\n", "57- %autoreload 2\"\"\")\n", "58- \n", "59-def scriptforTraintest():\n", "60- print(\"X_train,X_test,y_train,y_test=train_test_split(X,y,test_size=0.25,random_state=42)\")\n", "61- \n", "62-def scriptForCitation():\n", "63- print(\"\"\"

Görsel bu sayfadan alınmıştır

\"\"\")\n", "64- \n", "65-def pythonSomeInfo():\n", "66- print(\"system packages folder:\",sys.prefix, end=\"\\n\\n\")\n", "67- print(\"pip install folder:\",site.getsitepackages(), end=\"\\n\\n\") \n", "68- print(\"python version:\", sys.version, end=\"\\n\\n\")\n", "69- print(\"executables location:\",sys.executable, end=\"\\n\\n\")\n", "70- print(\"pip version:\", os.popen('pip version').read(), end=\"\\n\\n\")\n", "71- pathes= sys.path\n", "72- print(\"Python pathes\")\n", "73- for p in pathes:\n", "74- print(p)\n", "75-\n", "76-\n", "77-def showMemoryUsage():\n", "78- dict_={}\n", "79- global_vars = list(globals().items())\n", "80- for var, obj in global_vars:\n", "81- if not var.startswith('_'):\n", "82- dict_[var]=sys.getsizeof(obj)\n", "83- \n", "84- final={k: v for k, v in sorted(dict_.items(), key=lambda item: item[1],reverse=True)} \n", "85- print(final)\n", "86- \n", "87-def readfile(path,enc='cp1254'):\n", "88- with io.open(path, \"r\", encoding=enc) as f:\n", "89- return f.read()\n", "90-\n", "91-def getFirstItemFromDictionary(dict_):\n", "92- return next(iter(dict_)),next(iter(dict_.values()))\n", "93- \n", "94-\n", "95-\n", "96-def removeItemsFromList(self,list2,inplace=True): \n", "97- \"\"\"\n", "98- Extension method for list type. Removes items from list2 from list1.\n", "99- First, forbiddenfruit must be installed via https://pypi.org/project/forbiddenfruit/\n", "100- \"\"\" \n", "101- if inplace:\n", "102- for x in set(list2):\n", "103- self.remove(x)\n", "104- return self\n", "105- else:\n", "106- temp=self.copy()\n", "107- for x in set(list2):\n", "108- temp.remove(x)\n", "109- return temp\n", "110- \n", "111-curse(list, \"removeItemsFromList\", removeItemsFromList)\n", "112-\n", "113-\n", "114-\n", "115-\n", "116-\n" ] } ], "source": [ "#her satırın başına satır no ekleyelim\n", "dosya.seek(0)\n", "i=1\n", "for satır in dosya.readlines():\n", " print(\"{}-{}\".format(i,satır),end=\"\")\n", " i+=1" ] }, { "cell_type": "code", "execution_count": 296, "metadata": { "id": "Obwq_iNjNP2M" }, "outputs": [], "source": [ "#yarat\n", "yenidosya=io.open(\"test.txt\",\"w\")\n", "yenidosya.close()" ] }, { "cell_type": "code", "execution_count": 297, "metadata": { "id": "jWwIjeIKNP2M", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "f2b5d520-bd8a-49f1-87e1-deb9155ba69e" }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "6" ] }, "metadata": {}, "execution_count": 297 } ], "source": [ "#varolana yaz, sonuna ekleme\n", "yenidosya=io.open(\"test.txt\",\"a\")\n", "yenidosya.write(\"\\nselam\")\n", "yenidosya.flush() #hemen yazsın. bunu kullanmazsak yaptığımız değişiklikleri hemen görmeyiz" ] }, { "cell_type": "markdown", "metadata": { "id": "_FPZJr39NP2N" }, "source": [ "Güvenli dosya işlemleri" ] }, { "cell_type": "markdown", "metadata": { "id": "xjGs2hFlNP2N" }, "source": [ "Dosyalarla işiniz bitince kapatmak önemlidir. Kapandığından emin olmak için with bloğu içinde yazmak gerekir" ] }, { "cell_type": "code", "execution_count": 298, "metadata": { "scrolled": true, "id": "TuNhM5TlNP2N", "outputId": "7fed268e-fadd-4228-dcc9-cc917e176789", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "\n", "selam\n" ] } ], "source": [ "with io.open(\"test.txt\", \"r\") as dosya:\n", " print(dosya.read())" ] }, { "cell_type": "code", "execution_count": 299, "metadata": { "id": "gefRFUIKNP2N", "colab": { "base_uri": "https://localhost:8080/" }, "outputId": "6228198b-92de-4558-e601-4e48c71e5477" }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "0" ] }, "metadata": {}, "execution_count": 299 }, { "output_type": "execute_result", "data": { "text/plain": [ "13" ] }, "metadata": {}, "execution_count": 299 } ], "source": [ "#hem okuma hem yazma moduyla açıp başa bilgi ekleme\n", "with io.open(\"test.txt\", \"r+\") as f:\n", " content = f.read()\n", " f.seek(0) #Dosyayı başa sarıyoruz\n", " f.write(\"volkan\\n\"+content)" ] }, { "cell_type": "code", "source": [ "!rm test.txt" ], "metadata": { "id": "6tyKo6fQSnRi" }, "execution_count": 300, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "OijGzgTxNP2N" }, "source": [ "**Türkçe karakter**" ] }, { "cell_type": "markdown", "metadata": { "id": "WJ1vPazkNP2O" }, "source": [ "
\n", "utf-8 mi cp1254 mü?
\n", "\n", "https://python-istihza.yazbel.com/karakter_kodlama.html" ] }, { "cell_type": "code", "execution_count": 301, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T13:53:00.576889Z", "start_time": "2020-11-22T13:53:00.572903Z" }, "id": "Yn5SWIheNP2O", "outputId": "89047128-7dba-4908-c962-37a3d4994ab1", "colab": { "base_uri": "https://localhost:8080/", "height": 35 } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "'UTF-8'" ], "application/vnd.google.colaboratory.intrinsic+json": { "type": "string" } }, "metadata": {}, "execution_count": 301 } ], "source": [ "import locale\n", "locale.getpreferredencoding()" ] }, { "cell_type": "code", "execution_count": 302, "metadata": { "ExecuteTime": { "end_time": "2020-11-22T13:53:07.023663Z", "start_time": "2020-11-22T13:53:07.017681Z" }, "id": "nzTj3YM8NP2O", "outputId": "4d1b3682-7a90-4162-b804-34518a74cc23", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "import numpy as np\n", "import pandas as pd\n", "from sklearn.metrics import silhouette_samples, silhouette_score\n", "from sklearn.metrics import confusion_matrix, accuracy_score, recall_score, precision_score, f1_score\n", "from sklearn.metrics import roc_curve, precision_recall_curve, auc\n", "from sklearn.metrics import mean_squared_error,mean_absolute_error,r2_score\n", "import matplotlib.cm as cm\n", "import matplotlib.pyplot as plt\n", "from mpl_toolkits.mplot3d import Axes3D\n", "from sklearn.cluster import KMeans\n", "from sklearn.neighbors import NearestNeighbors\n", "from sklearn.preprocessing import LabelEncoder, OneHotEncoder,binarize\n", "from sklearn.pipeline import Pipeline \n", "import os, sys, site\n", "import itertools \n", "from numpy.random import uniform\n", "from random import sample, seed\n", "from math import isnan\n", "from multiprocessing import Pool\n", "from scipy.spatial import distance\n", "from sklearn.metrics.pairwise import cosine_similarity\n", "from sklearn.model_selection import learning_curve\n", "import networkx as nx\n", "from sklearn.experimental import enable_halving_search_cv \n", "from sklearn.model_selection import RandomizedSearchCV,GridSearchCV,HalvingGridSearchCV,HalvingRandomSearchCV\n", "import warnings\n", "import statsmodels.api as sm\n", "import statsmodels.stats.api as sms\n", "import statsmodels.formula.api as smf\n", "\n", "def adjustedr2(R_sq,y,y_pred,x):\n", " return 1 - (1-R_sq)*(len(y)-1)/(len(y_pred)-x.shape[1]-1)\n", "\n", "def calculate_aic_bic(n, mse, num_params):\n", " \"\"\"\n", " n=number of instances in y \n", " \"\"\" \n", " aic = n *np.log(mse) + 2 * num_params\n", " bic = n * np.log(mse) + num_params * np.log(n)\n", " # ssr = fitted.ssr #residual sum of squares\n", " # AIC = N + N*np.log(2.0*np.pi*ssr/N)+2.0*(p+1)\n", " # print(AIC)\n", " # BIC = N + N*np.log(2.0*np.pi*ssr/N) + p*np.log(N)\n", " # print(BIC)\n", " return aic, bic \n", "\n", " \n", "def printScores(y_test,y_pred,x=None,*, alg_type='c',f1avg=None):\n", " \"\"\" \n", " prints the available performanse scores.\n", " Args:\n", " alg_type: c for classfication, r for regressin\n", " f1avg: if None, taken as binary.\n", " \"\"\"\n", " if alg_type=='c':\n", " acc=accuracy_score(y_test,y_pred)\n", " print(\"Accuracy:\",acc)\n", " recall=recall_score(y_test,y_pred)\n", " print(\"Recall:\",recall)\n", " precision=precision_score(y_test,y_pred)\n", " print(\"Precision:\",precision)\n", " if f1avg is None:\n", " f1=f1_score(y_test,y_pred)\n", " else:\n", " f1=f1_score(y_test,y_pred,average=f1avg)\n", " print(\"F1:\",f1)\n", " return acc,recall,precision,f1\n", " else:\n", " mse=mean_squared_error(y_test,y_pred) #RMSE için squared=False yapılabilir ama bize mse de lazım\n", " rmse=round(np.sqrt(mse),2)\n", " print(\"RMSE:\",rmse)\n", " mae=round(mean_absolute_error(y_test,y_pred),2)\n", " print(\"MAE:\",mae) \n", " r2=round(r2_score(y_test,y_pred),2)\n", " print(\"r2:\",r2)\n", " adjr2=round(adjustedr2(r2_score(y_test,y_pred),y_test,y_pred,x),2)\n", " print(\"Adjusted R2:\",adjr2)\n", " aic, bic=calculate_aic_bic(len(y_test),mse,len(x))\n", " print(\"AIC:\",round(aic,2))\n", " print(\"BIC:\",round(bic,2))\n", " return (rmse,mae,r2,adjr2,round(aic,2),round(bic,2))\n", "\n", "def draw_sihoutte(range_n_clusters,data,isbasic=True,printScores=True,random_state=42):\n", " \"\"\"\n", " - isbasic:if True, plots scores as line chart whereas false, plots the sihoutte chart.\n", " - taken from https://scikit-learn.org/stable/auto_examples/cluster/plot_kmeans_silhouette_analysis.html and modified as needed.\n", " \"\"\"\n", " if isbasic==False:\n", " silhouette_max=0\n", " for n_clusters in range_n_clusters:\n", " # Create a subplot with 1 row and 2 columns\n", " fig, (ax1, ax2) = plt.subplots(1, 2)\n", " fig.set_size_inches(12,4)\n", "\n", " ax1.set_xlim([-1, 1])\n", " # The (n_clusters+1)*10 is for inserting blank space between silhouette\n", " # plots of individual clusters, to demarcate them clearly.\n", " ax1.set_ylim([0, len(data) + (n_clusters + 1) * 10])\n", "\n", " # Initialize the clusterer with n_clusters value and a random generator\n", " # seed of 10 for reproducibility.\n", " clusterer = KMeans(n_clusters=n_clusters, random_state=random_state)\n", " cluster_labels = clusterer.fit_predict(data)\n", "\n", " # The silhouette_score gives the average value for all the samples.\n", " # This gives a perspective into the density and separation of the formed\n", " # clusters\n", " silhouette_avg = silhouette_score(data, cluster_labels)\n", " if silhouette_avg>silhouette_max:\n", " silhouette_max,nc=silhouette_avg,n_clusters\n", " print(\"For n_clusters =\", n_clusters,\n", " \"The average silhouette_score is :\", silhouette_avg)\n", "\n", " # Compute the silhouette scores for each sample\n", " sample_silhouette_values = silhouette_samples(data, cluster_labels)\n", "\n", " y_lower = 10\n", " for i in range(n_clusters):\n", " # Aggregate the silhouette scores for samples belonging to\n", " # cluster i, and sort them\n", " ith_cluster_silhouette_values = \\\n", " sample_silhouette_values[cluster_labels == i]\n", "\n", " ith_cluster_silhouette_values.sort()\n", "\n", " size_cluster_i = ith_cluster_silhouette_values.shape[0]\n", " y_upper = y_lower + size_cluster_i\n", "\n", " color = cm.nipy_spectral(float(i) / n_clusters)\n", " ax1.fill_betweenx(np.arange(y_lower, y_upper),\n", " 0, ith_cluster_silhouette_values,\n", " facecolor=color, edgecolor=color, alpha=0.7)\n", "\n", " # Label the silhouette plots with their cluster numbers at the middle\n", " ax1.text(-0.05, y_lower + 0.5 * size_cluster_i, str(i))\n", "\n", " # Compute the new y_lower for next plot\n", " y_lower = y_upper + 10 # 10 for the 0 samples\n", "\n", " ax1.set_title(\"The silhouette plot for the various clusters.\")\n", " ax1.set_xlabel(\"The silhouette coefficient values\")\n", " ax1.set_ylabel(\"Cluster label\")\n", "\n", " # The vertical line for average silhouette score of all the values\n", " ax1.axvline(x=silhouette_avg, color=\"red\", linestyle=\"--\")\n", "\n", " ax1.set_yticks([]) # Clear the yaxis labels / ticks\n", " ax1.set_xticks([-0.1, 0, 0.2, 0.4, 0.6, 0.8, 1])\n", "\n", " # 2nd Plot showing the actual clusters formed\n", " colors = cm.nipy_spectral(cluster_labels.astype(float) / n_clusters)\n", " ax2.scatter(data[:, 0], data[:, 1], marker='.', s=30, lw=0, alpha=0.7,\n", " c=colors, edgecolor='k')\n", "\n", " # Labeling the clusters\n", " centers = clusterer.cluster_centers_\n", " # Draw white circles at cluster centers\n", " ax2.scatter(centers[:, 0], centers[:, 1], marker='o',\n", " c=\"white\", alpha=1, s=200, edgecolor='k')\n", "\n", " for i, c in enumerate(centers):\n", " ax2.scatter(c[0], c[1], marker='$%d$' % i, alpha=1,\n", " s=50, edgecolor='k')\n", "\n", " ax2.set_title(\"The visualization of the clustered data.\")\n", " ax2.set_xlabel(\"Feature space for the 1st feature\")\n", " ax2.set_ylabel(\"Feature space for the 2nd feature\")\n", "\n", " plt.suptitle((\"Silhouette analysis for KMeans clustering on sample data \"\n", " \"with n_clusters = %d\" % n_clusters),\n", " fontsize=14, fontweight='bold') \n", " plt.show()\n", " print(f\"Best score is {silhouette_max} for {nc}\")\n", " else:\n", " ss = []\n", " for n in range_n_clusters:\n", " kmeans = KMeans(n_clusters=n, random_state=random_state)\n", " kmeans.fit_transform(data)\n", " labels = kmeans.labels_\n", " score = silhouette_score(data, labels)\n", " ss.append(score)\n", " if printScores==True:\n", " print(n,score)\n", " plt.plot(range_n_clusters,ss)\n", " plt.xticks(range_n_clusters) #so it shows all the ticks\n", "\n", "def drawEpsilonDecider(data,n):\n", " \"\"\"\n", " for DBSCAN\n", " n: # of neighbours(in the nearest neighbour calculation, the point itself will appear as the first nearest neighbour. so, this should be\n", " given as min_samples+1.\n", " data:numpy array\n", " \"\"\"\n", " neigh = NearestNeighbors(n_neighbors=n)\n", " nbrs = neigh.fit(data)\n", " distances, indices = nbrs.kneighbors(data)\n", " distances = np.sort(distances, axis=0)\n", " distances = distances[:,1]\n", " plt.ylabel(\"eps\")\n", " plt.xlabel(\"number of data points\")\n", " plt.plot(distances)\n", " \n", "def draw_elbow(ks,data):\n", " wcss = []\n", " for i in ks:\n", " kmeans = KMeans(n_clusters=i, init='k-means++', max_iter=300, n_init=10, random_state=0) \n", " kmeans.fit(data)\n", " wcss.append(kmeans.inertia_)\n", " plt.plot(ks, wcss)\n", " plt.title('Elbow Method')\n", " plt.xlabel('# of clusters')\n", " plt.ylabel('WCSS')\n", " plt.xticks(ks)\n", " plt.show()\n", " \n", "def biplot(score,coeff,y,variance,labels=None):\n", " \"\"\"\n", " PCA biplot.\n", " Found at https://stackoverflow.com/questions/39216897/plot-pca-loadings-and-loading-in-biplot-in-sklearn-like-rs-autoplot\n", " \"\"\"\n", " xs = score[:,0]\n", " ys = score[:,1]\n", " n = coeff.shape[0]\n", " scalex = 1.0/(xs.max() - xs.min())\n", " scaley = 1.0/(ys.max() - ys.min())\n", " plt.scatter(xs * scalex,ys * scaley, c = y)\n", " for i in range(n):\n", " plt.arrow(0, 0, coeff[i,0], coeff[i,1],color = 'r',alpha = 0.5)\n", " if labels is None:\n", " plt.text(coeff[i,0]* 1.15, coeff[i,1] * 1.15, \"Var\"+str(i+1), color = 'g', ha = 'center', va = 'center')\n", " else:\n", " plt.text(coeff[i,0]* 1.15, coeff[i,1] * 1.15, labels[i], color = 'g', ha = 'center', va = 'center')\n", " plt.xlim(-1,1)\n", " plt.ylim(-1,1)\n", " plt.xlabel(\"PC{},Variance:{}\".format(1,variance[0]))\n", " plt.ylabel(\"PC{},Variance:{}\".format(2,variance[1]))\n", " plt.grid()\n", "\n", " \n", " \n", "\n", "def get_feature_names_from_columntransformer(ct):\n", " \"\"\"\n", " returns feature names in a dataframe passet to a column transformer. Useful if you have lost the names due to conversion to numpy.\n", " if it doesn't work, try out the one at https://johaupt.github.io/blog/columnTransformer_feature_names.html or at https://lifesaver.codes/answer/cannot-get-feature-names-after-columntransformer-12525\n", " \"\"\"\n", " final_features=[]\n", " try:\n", " \n", " for trs in ct.transformers_:\n", " trName=trs[0]\n", " trClass=trs[1]\n", " features=trs[2]\n", " if isinstance(trClass,Pipeline): \n", " n,tr=zip(*trClass.steps)\n", " for t in tr: #t is a transformator object, tr is the list of all transoformators in the pipeline \n", " if isinstance(t,OneHotEncoder):\n", " for f in t.get_feature_names_out(features):\n", " final_features.append(\"OHE_\"+f) \n", " break\n", " else: #if not found onehotencoder, add the features directly\n", " for f in features:\n", " final_features.append(f) \n", " elif isinstance(trClass,OneHotEncoder): #?type(trClass)==OneHotEncoder:\n", " for f in trClass.get_feature_names_out(features):\n", " final_features.append(\"OHE_\"+f) \n", " else:\n", " #remainders\n", " if trName==\"remainder\":\n", " for i in features:\n", " final_features.append(ct.feature_names_in_[i])\n", " #all the others\n", " else:\n", " for f in features:\n", " final_features.append(f) \n", " except AttributeError:\n", " print(\"Your sklearn version may be old and you may need to upgrade it via 'python -m pip install scikit-learn -U'\")\n", "\n", " return final_features \n", "\n", "def featureImportanceEncoded(feature_importance_array,feature_names,figsize=(8,6)):\n", " \"\"\"\n", " plots the feature importance plot.\n", " feature_importance_array:feature_importance_ attribute\n", " \"\"\"\n", " plt.figure(figsize=figsize)\n", " dfimp=pd.DataFrame(feature_importance_array.reshape(-1,1).T,columns=feature_names).T\n", " dfimp.index.name=\"Encoded\"\n", " dfimp.rename(columns={0: \"Importance\"},inplace=True)\n", " dfimp.reset_index(inplace=True)\n", " dfimp[\"Feature\"]=dfimp[\"Encoded\"].apply(lambda x:x[4:].split('_')[0] if \"OHE\" in x else x)\n", " dfimp.groupby(by='Feature')[\"Importance\"].sum().sort_values().plot(kind='barh');\n", " \n", " \n", "def compareEstimatorsInGridSearch(gs,tableorplot='plot',figsize=(10,5),est=\"param_clf\"):\n", " \"\"\"\n", " Gives a comparison table/plot of the estimators in a gridsearch.\n", " \"\"\"\n", " cvres = gs.cv_results_\n", " cv_results = pd.DataFrame(cvres)\n", " cv_results[est]=cv_results[est].apply(lambda x:str(x).split('(')[0])\n", " cols={\"mean_test_score\":\"MAX of mean_test_score\",\"mean_fit_time\":\"MIN of mean_fit_time\"}\n", " summary=cv_results.groupby(by=est).agg({\"mean_test_score\":\"max\", \"mean_fit_time\":\"min\"}).rename(columns=cols)\n", " summary.sort_values(by='MAX of mean_test_score', ascending=False,inplace=True)\n", " \n", " \n", " if tableorplot=='table':\n", " return summary\n", " else:\n", " _, ax1 = plt.subplots(figsize=figsize)\n", " color = 'tab:red'\n", " ax1.xaxis.set_ticks(range(len(summary)))\n", " ax1.set_xticklabels(summary.index, rotation=45,ha='right')\n", " \n", " ax1.set_ylabel('MAX of mean_test_score', color=color)\n", " ax1.bar(summary.index, summary['MAX of mean_test_score'], color=color)\n", " ax1.tick_params(axis='y', labelcolor=color)\n", " ax1.set_ylim(0,summary[\"MAX of mean_test_score\"].max()*1.1)\n", "\n", " ax2 = ax1.twinx() \n", " color = 'tab:blue'\n", " ax2.set_ylabel('MIN of mean_fit_time', color=color) \n", " ax2.plot(summary.index, summary['MIN of mean_fit_time'], color=color)\n", " ax2.tick_params(axis='y', labelcolor=color) \n", " ax2.set_ylim(0,summary[\"MIN of mean_fit_time\"].max()*1.1)\n", "\n", " plt.show() \n", "\n", "def plot_confusion_matrix(cm, classes,\n", " normalize=False,\n", " title='Confusion matrix',\n", " cmap=plt.cm.Blues):\n", " \"\"\"\n", " Depreceated. use 'sklearn.metrics.ConfusionMatrixDisplay(cm).plot();'\n", " \"\"\"\n", " warnings.warn(\"use 'sklearn.metrics.ConfusionMatrixDisplay(cm).plot();'\") \n", " \n", "def CheckForClusteringTendencyWithHopkins(X,random_state=42): \n", " \"\"\"\n", " taken from https://matevzkunaver.wordpress.com/2017/06/20/hopkins-test-for-cluster-tendency/\n", " X:numpy array or dataframe\n", " the closer to 1, the higher probability of clustering tendency \n", " X must be scaled priorly.\n", " \"\"\"\n", " \n", " d = X.shape[1]\n", " #d = len(vars) # columns\n", " n = len(X) # rows\n", " m = int(0.1 * n) # heuristic from article [1]\n", " if type(X)==np.ndarray:\n", " nbrs = NearestNeighbors(n_neighbors=1).fit(X)\n", " else:\n", " nbrs = NearestNeighbors(n_neighbors=1).fit(X.values)\n", " seed(random_state) \n", " rand_X = sample(range(0, n, 1), m)\n", " \n", " ujd = []\n", " wjd = []\n", " for j in range(0, m):\n", " #-------------------bi ara random state yap----------\n", " u_dist, _ = nbrs.kneighbors(uniform(np.amin(X,axis=0),np.amax(X,axis=0),d).reshape(1, -1), 2, return_distance=True)\n", " ujd.append(u_dist[0][1])\n", " if type(X)==np.ndarray:\n", " w_dist, _ = nbrs.kneighbors(X[rand_X[j]].reshape(1, -1), 2, return_distance=True)\n", " else:\n", " w_dist, _ = nbrs.kneighbors(X.iloc[rand_X[j]].values.reshape(1, -1), 2, return_distance=True)\n", " wjd.append(w_dist[0][1])\n", " \n", " H = sum(ujd) / (sum(ujd) + sum(wjd))\n", " if isnan(H):\n", " print(ujd, wjd)\n", " H = 0\n", " \n", " return H \n", "\n", "def getNumberofCatsAndNumsFromDatasets(path,size=10_000_000):\n", " \"\"\"\n", " returns the number of features by their main type(i.e categorical or numeric or datetime)\n", " args:\n", " path:path of the files residing in.\n", " size:size of the file(default is ~10MB). if chosen larger, it will take longer to return.\n", " \"\"\"\n", " os.chdir(path)\n", " files=os.listdir()\n", " liste=[]\n", " for d in files: \n", " try:\n", " if os.path.isfile(d) and os.path.getsize(d)` for the various\n", " cross-validators that can be used here.\n", "\n", " n_jobs : int or None, default=None\n", " Number of jobs to run in parallel.\n", " ``None`` means 1 unless in a :obj:`joblib.parallel_backend` context.\n", " ``-1`` means using all processors. See :term:`Glossary `\n", " for more details.\n", "\n", " train_sizes : array-like of shape (n_ticks,)\n", " Relative or absolute numbers of training examples that will be used to\n", " generate the learning curve. If the ``dtype`` is float, it is regarded\n", " as a fraction of the maximum size of the training set (that is\n", " determined by the selected validation method), i.e. it has to be within\n", " (0, 1]. Otherwise it is interpreted as absolute sizes of the training\n", " sets. Note that for classification the number of samples usually have\n", " to be big enough to contain at least one sample from each class.\n", " (default: np.linspace(0.1, 1.0, 5))\n", " \"\"\"\n", " if axes is None:\n", " _, axes = plt.subplots(1, 3, figsize=(20, 5))\n", "\n", " axes[0].set_title(title)\n", " if ylim is not None:\n", " axes[0].set_ylim(*ylim)\n", " axes[0].set_xlabel(\"Training examples\")\n", " axes[0].set_ylabel(\"Score\")\n", "\n", " train_sizes, train_scores, test_scores, fit_times, _ = learning_curve(\n", " estimator,\n", " X,\n", " y,\n", " cv=cv,\n", " n_jobs=n_jobs,\n", " train_sizes=train_sizes,\n", " return_times=True,\n", " random_state=random_state\n", " )\n", " train_scores_mean = np.mean(train_scores, axis=1)\n", " train_scores_std = np.std(train_scores, axis=1)\n", " test_scores_mean = np.mean(test_scores, axis=1)\n", " test_scores_std = np.std(test_scores, axis=1)\n", " fit_times_mean = np.mean(fit_times, axis=1)\n", " fit_times_std = np.std(fit_times, axis=1)\n", "\n", " # Plot learning curve\n", " axes[0].grid()\n", " axes[0].fill_between(\n", " train_sizes,\n", " train_scores_mean - train_scores_std,\n", " train_scores_mean + train_scores_std,\n", " alpha=0.1,\n", " color=\"r\",\n", " )\n", " axes[0].fill_between(\n", " train_sizes,\n", " test_scores_mean - test_scores_std,\n", " test_scores_mean + test_scores_std,\n", " alpha=0.1,\n", " color=\"g\",\n", " )\n", " axes[0].plot(\n", " train_sizes, train_scores_mean, \"o-\", color=\"r\", label=\"Training score\"\n", " )\n", " axes[0].plot(\n", " train_sizes, test_scores_mean, \"o-\", color=\"g\", label=\"Cross-validation score\"\n", " )\n", " axes[0].legend(loc=\"best\")\n", "\n", " # Plot n_samples vs fit_times\n", " axes[1].grid()\n", " axes[1].plot(train_sizes, fit_times_mean, \"o-\")\n", " axes[1].fill_between(\n", " train_sizes,\n", " fit_times_mean - fit_times_std,\n", " fit_times_mean + fit_times_std,\n", " alpha=0.1,\n", " )\n", " axes[1].set_xlabel(\"Training examples\")\n", " axes[1].set_ylabel(\"fit_times\")\n", " axes[1].set_title(\"Scalability of the model\")\n", "\n", " # Plot fit_time vs score\n", " fit_time_argsort = fit_times_mean.argsort()\n", " fit_time_sorted = fit_times_mean[fit_time_argsort]\n", " test_scores_mean_sorted = test_scores_mean[fit_time_argsort]\n", " test_scores_std_sorted = test_scores_std[fit_time_argsort]\n", " axes[2].grid()\n", " axes[2].plot(fit_time_sorted, test_scores_mean_sorted, \"o-\")\n", " axes[2].fill_between(\n", " fit_time_sorted,\n", " test_scores_mean_sorted - test_scores_std_sorted,\n", " test_scores_mean_sorted + test_scores_std_sorted,\n", " alpha=0.1,\n", " )\n", " axes[2].set_xlabel(\"fit_times\")\n", " axes[2].set_ylabel(\"Score\")\n", " axes[2].set_title(\"Performance of the model\")\n", "\n", " plt.show()\n", "\n", "\n", "def drawNeuralNetwork(layers,figsize=(10,8)):\n", " \"\"\"\n", " Draws a represantion of the neural network using networkx.\n", " layers:list of the # of layers including input and output.\n", " \"\"\" \n", " plt.figure(figsize=figsize)\n", " pos={} \n", " for e,l in enumerate(layers):\n", " for i in range(l):\n", " pos[str(l)+\"_\"+str(i)]=((e+1)*50,i*5+50)\n", "\n", "\n", " X=nx.Graph()\n", " nx.draw_networkx_nodes(X,pos,nodelist=pos.keys(),node_color='r')\n", " X.add_nodes_from(pos.keys())\n", "\n", " edgelist=[] #list of tuple\n", " for e,l in enumerate(layers):\n", " for i in range(l):\n", " try:\n", " for k in range(layers[e+1]):\n", " try:\n", " edgelist.append((str(l)+\"_\"+str(i),str(layers[e+1])+\"_\"+str(k)))\n", " except:\n", " pass\n", " except:\n", " pass\n", "\n", "\n", " X.add_edges_from(edgelist)\n", " for n, p in pos.items():\n", " X.nodes[n]['pos'] = p \n", "\n", " nx.draw(X, pos); \n", "\n", "def draw_network_graph(ws):\n", " \"\"\"\n", " Draws a network graph of a neural network with dynamic weights.\n", "\n", " Args:\n", " ws: A list of weight matrices.\n", " \"\"\"\n", " # Create a directed graph\n", " G = nx.DiGraph()\n", "\n", " # Add nodes\n", " layer_count = len(ws) + 1 # Include input layer\n", " node_count = [ws[0].shape[0]] + [w.shape[1] for w in ws]\n", "\n", " for layer in range(layer_count):\n", " if layer == 0:\n", " for i in range(node_count[layer]):\n", " G.add_node(f\"Input {i+1}\", layer=layer)\n", " elif layer == layer_count - 1:\n", " for i in range(node_count[layer]):\n", " G.add_node(f\"Output {i+1}\", layer=layer)\n", " else:\n", " for i in range(node_count[layer]):\n", " G.add_node(f\"Hidden {layer}_{i+1}\", layer=layer)\n", "\n", " # Add edges with weights\n", " for layer in range(layer_count - 1):\n", " for i in range(node_count[layer]):\n", " for j in range(node_count[layer + 1]):\n", " if layer == 0:\n", " G.add_edge(f\"Input {i+1}\", f\"Hidden {layer + 1}_{j+1}\", weight=ws[layer][i, j])\n", " elif layer == layer_count - 2:\n", " G.add_edge(f\"Hidden {layer}_{i+1}\", f\"Output {j+1}\", weight=ws[layer][i, j])\n", " else:\n", " G.add_edge(f\"Hidden {layer}_{i+1}\", f\"Hidden {layer + 1}_{j+1}\", weight=ws[layer][i, j])\n", "\n", " # Draw the graph\n", " pos = {}\n", " pos.update({node: (0, i) for i, node in enumerate(\n", " [f\"Input {i+1}\" for i in range(node_count[0])]\n", " )})\n", " pos.update({node: (layer, i) for layer in range(1, layer_count -1) for i, node in enumerate(\n", " [f\"Hidden {layer}_{i+1}\" for i in range(node_count[layer])]\n", " )})\n", " pos.update({node: (layer_count - 1, i) for i, node in enumerate(\n", " [f\"Output {i+1}\" for i in range(node_count[-1])]\n", " )})\n", "\n", " nx.draw(G, pos, with_labels=True, node_size=1000, node_color='lightblue', font_size=10)\n", "\n", " # Add edge labels with weights\n", " edge_labels = {(u, v): f\"{d['weight']:.2f}\" for u, v, d in G.edges(data=True)}\n", " nx.draw_networkx_edge_labels(G, pos, edge_labels=edge_labels)\n", "\n", " plt.show()\n", "\n", "def plotROC(y_test,X_test,estimator,pos_label=1,figsize=(6,6)):\n", " cm = confusion_matrix(y_test, estimator.predict(X_test)) \n", " fpr, tpr, _ = roc_curve(y_test, estimator.predict_proba(X_test)[:,1],pos_label=pos_label)\n", " roc_auc = auc(fpr, tpr) #or roc_auc_score(y_test, y_scores)\n", " plt.figure(figsize=figsize)\n", " plt.plot(fpr, tpr, label='(ROC-AUC = %0.2f)' % roc_auc)\n", " plt.plot([0, 1], [0, 1], 'k--')\n", " tn, fp, fn, tp = [i for i in cm.ravel()]\n", " plt.plot(fp/(fp+tn), tp/(tp+fn), 'ro', markersize=8, label='Decision Point(Optimal threshold)')\n", " plt.xlim([0.0, 1.0])\n", " plt.ylim([0.0, 1.05])\n", " plt.xlabel('False Positive Rate(1-sepecifity)')\n", " plt.ylabel('True Positive Rate(Recall/Sensitivity)')\n", " plt.title('ROC Curve (TPR vs FPR at each probability threshold)')\n", " plt.legend(loc=\"lower right\")\n", " plt.show();\n", "\n", "def plot_precision_recall_curve(y_test_encoded,X_test,estimator,threshs=np.linspace(0.0, 0.98, 40),figsize=(16,6)):\n", " \"\"\"\n", " y_test should be labelencoded.\n", " \"\"\"\n", " pred_prob = estimator.predict_proba(X_test) \n", " precision, recall, thresholds = precision_recall_curve(y_test_encoded, pred_prob[:,1])\n", " pr_auc = auc(recall, precision) \n", "\n", " Xt = [] ; Yp = [] ; Yr = [] \n", " for thresh in threshs:\n", " with warnings.catch_warnings():\n", " warnings.filterwarnings(\"error\")\n", " try:\n", " y_pred = binarize(pred_prob, threshold=thresh)[:,1]\n", " Xt.append(thresh)\n", " Yp.append(precision_score(y_test_encoded, y_pred)) #,zero_division=1\n", " Yr.append(recall_score(y_test_encoded, y_pred))\n", " except Warning as e:\n", " print(f\"{thresh:.2f}, error , probably division by zero\")\n", "\n", " \n", " plt.figure(figsize=figsize)\n", " plt.subplot(121)\n", " plt.plot(Xt, Yp, \"--\", label='Precision', color='red')\n", " plt.plot(Xt, Yr, \"--\", label='Recall', color='blue')\n", " plt.title(\"Precision vs Recall based on decision threshold\")\n", " plt.xlabel('Decision threshold') ; plt.ylabel('Precision - Recall')\n", " plt.legend()\n", " plt.subplot(122)\n", " plt.step(Yr, Yp, color='black', label='LR (PR-AUC = %0.2f)' % pr_auc)\n", " # calculate the no skill line as the proportion of the positive class (0.145)\n", " no_skill = len(y_test_encoded[y_test_encoded==1]) / len(y_test_encoded)\n", " # plot the no skill precision-recall curve\n", " plt.plot([0, 1], [no_skill, no_skill], linestyle='--', color='green', label='No Skill')\n", " # plot the perfect PR curve\n", " plt.plot([0, 1],[1, 1], color='blue', label='Perfect')\n", " plt.plot([1, 1],[1, len(y_test_encoded[y_test_encoded==1]) / len(y_test_encoded)], color='blue')\n", " plt.title('PR Curve')\n", " plt.xlabel('Recall: TP / (TP+FN)') ; plt.ylabel('Precison: TP / (TP+FP)')\n", " plt.legend(loc=\"upper right\")\n", " plt.show();\n", "\n", "\n", "def find_best_cutoff_for_classification(estimator, y_test_le, X_test, costlist,threshs=np.linspace(0., 0.98, 20)): \n", " \"\"\"\n", " y_test should be labelencoded as y_test_le\n", " costlist=cost list for TN, TP, FN, FP\n", " \"\"\"\n", " y_pred_prob = estimator.predict_proba(X_test)\n", " y_pred = estimator.predict(X_test)\n", " Xp = [] ; Yp = [] # initialization\n", "\n", " print(\"Cutoff\\t Cost/Instance\\t Accuracy\\t FN\\t FP\\t TP\\t TN\\t Recall\\t Precision F1-score\")\n", " for cutoff in threshs:\n", " with warnings.catch_warnings():\n", " warnings.filterwarnings(\"error\")\n", " try:\n", " y_pred = binarize(y_pred_prob, threshold=cutoff)[:,1]\n", " cm = confusion_matrix(y_test_le, y_pred)\n", " TP = cm[1,1]\n", " TN = cm[0,0]\n", " FP = cm[0,1]\n", " FN = cm[1,0]\n", " cost = costlist[0]*TN + costlist[1]*TP + costlist[2]*FN + costlist[3]*FP\n", " cost_per_instance = cost/len(y_test_le)\n", " Xp.append(cutoff)\n", " Yp.append(cost_per_instance)\n", " acc=accuracy_score(y_test_le, y_pred)\n", " rec = cm[1,1]/(cm[1,1]+cm[1,0])\n", " pre = cm[1,1]/(cm[1,1]+cm[0,1])\n", " f1 = 2*pre*rec/(pre+rec)\n", " print(f\"{cutoff:.2f}\\t {cost_per_instance:.2f}\\t\\t {acc:.3f}\\t\\t {FN}\\t {FP}\\t {TP}\\t {TN}\\t {rec:.3f}\\t {pre:.3f}\\t {f1:.3f}\")\n", " except Warning as e:\n", " print(f\"{cutoff:.2f}\\t {cost_per_instance:.2f}\\t\\t {acc:.3f}\\t\\t {FN}\\t {FP}\\t {TP}\\t {TN}\\t error might have happened from here anywhere\")\n", "\n", " plt.figure(figsize=(10,6))\n", " plt.plot(Xp, Yp)\n", " plt.xlabel('Threshold value for probability')\n", " plt.ylabel('Cost per instance')\n", " plt.axhline(y=min(Yp), xmin=0., xmax=1., linewidth=1, color = 'r')\n", " plt.show();\n", "\n", "\n", "def plot_gain_and_lift(estimator,X_test,y_test,pos_label=\"Yes\",figsize=(16,6)):\n", " \"\"\" \n", " y_test as numpy array\n", " prints the gain and lift values and plots the charts. \n", " \"\"\"\n", " prob_df=pd.DataFrame({\"Prob\":estimator.predict_proba(X_test)[:,1]})\n", " prob_df[\"label\"]=np.where(y_test==pos_label,1,0)\n", " prob_df = prob_df.sort_values(by=\"Prob\",ascending=False)\n", " prob_df['Decile'] = pd.qcut(prob_df['Prob'], 10, labels=list(range(1,11))[::-1])\n", "\n", " #Calculate the actual churn in each decile\n", " res = pd.crosstab(prob_df['Decile'], prob_df['label'])[1].reset_index().rename(columns = {1: 'Number of Responses'})\n", " lg = prob_df['Decile'].value_counts(sort = False).reset_index().rename(columns = {'Decile': 'Number of Cases', 'index': 'Decile'})\n", " lg = pd.merge(lg, res, on = 'Decile').sort_values(by = 'Decile', ascending = False).reset_index(drop = True)\n", " #Calculate the cumulative\n", " lg['Cumulative Responses'] = lg['Number of Responses'].cumsum()\n", " #Calculate the percentage of positive in each decile compared to the total nu\n", " lg['% of Events'] = np.round(((lg['Number of Responses']/lg['Number of Responses'].sum())*100),2)\n", " #Calculate the Gain in each decile\n", " lg['Gain'] = lg['% of Events'].cumsum()\n", " lg['Decile'] = lg['Decile'].astype('int')\n", " lg['lift'] = np.round((lg['Gain']/(lg['Decile']*10)),2)\n", " display(lg)\n", "\n", " plt.figure(figsize=figsize)\n", " plt.subplot(121)\n", " plt.plot(lg[\"Decile\"],lg[\"lift\"],label=\"Model\")\n", " plt.plot(lg[\"Decile\"],[1 for i in range(10)],label=\"Random\")\n", " plt.title(\"Lift Chart\")\n", " plt.legend()\n", " plt.xlabel(\"Decile\")\n", " plt.ylabel(\"Lift\") \n", " \n", " plt.subplot(122)\n", " plt.plot(lg[\"Decile\"],lg[\"Gain\"],label=\"Model\")\n", " plt.plot(lg[\"Decile\"],[10*(i+1) for i in range(10)],label=\"Random\")\n", " plt.title(\"Gain Chart\")\n", " plt.legend()\n", " plt.xlabel(\"Decile\")\n", " plt.ylabel(\"Gain\")\n", " plt.xlim(0,11)\n", " plt.ylim(0,110)\n", " plt.show(); \n", "\n", "def plot_gain_and_lift_orj(estimator,X_test,y_test,pos_label=\"Yes\"):\n", " \"\"\" \n", " y_test as numpy array\n", " prints the gain and lift values and plots the charts. \n", " \"\"\"\n", " prob_df=pd.DataFrame({\"Prob\":estimator.predict_proba(X_test)[:,1]})\n", " prob_df[\"label\"]=np.where(y_test==pos_label,1,0)\n", " prob_df = prob_df.sort_values(by=\"Prob\",ascending=False)\n", " prob_df['Decile'] = pd.qcut(prob_df['Prob'], 10, labels=list(range(1,11))[::-1])\n", "\n", " #Calculate the actual churn in each decile\n", " res = pd.crosstab(prob_df['Decile'], prob_df['label'])[1].reset_index().rename(columns = {1: 'Number of Responses'})\n", " lg = prob_df['Decile'].value_counts(sort = False).reset_index().rename(columns = {'Decile': 'Number of Cases', 'index': 'Decile'})\n", " lg = pd.merge(lg, res, on = 'Decile').sort_values(by = 'Decile', ascending = False).reset_index(drop = True)\n", " #Calculate the cumulative\n", " lg['Cumulative Responses'] = lg['Number of Responses'].cumsum()\n", " #Calculate the percentage of positive in each decile compared to the total nu\n", " lg['% of Events'] = np.round(((lg['Number of Responses']/lg['Number of Responses'].sum())*100),2)\n", " #Calculate the Gain in each decile\n", " lg['Gain'] = lg['% of Events'].cumsum()\n", " lg['Decile'] = lg['Decile'].astype('int')\n", " lg['lift'] = np.round((lg['Gain']/(lg['Decile']*10)),2)\n", " display(lg)\n", " \n", " plt.plot(lg[\"Decile\"],lg[\"lift\"],label=\"Model\")\n", " plt.plot(lg[\"Decile\"],[1 for i in range(10)],label=\"Random\")\n", " plt.title(\"Lift Chart\")\n", " plt.legend()\n", " plt.xlabel(\"Decile\")\n", " plt.ylabel(\"Lift\")\n", " plt.show();\n", " \n", " plt.plot(lg[\"Decile\"],lg[\"Gain\"],label=\"Model\")\n", " plt.plot(lg[\"Decile\"],[10*(i+1) for i in range(10)],label=\"Random\")\n", " plt.title(\"Gain Chart\")\n", " plt.legend()\n", " plt.xlabel(\"Decile\")\n", " plt.ylabel(\"Gain\")\n", " plt.xlim(0,11)\n", " plt.ylim(0,110)\n", " plt.show(); \n", "\n", "def linear_model_feature_importance(estimator,preprocessor,feature_selector=None,clfreg_name=\"clf\"):\n", " \"\"\"\n", " plots the feature importance, namely coefficients for linear models.\n", " args:\n", " estimator:either pipeline or gridsearch/randomizedsearch object\n", " preprocessor:variable name of the preprocessor, which is a columtransformer\n", " feature_selector:if there is a feature selector step, its name.\n", " clfreg_name:name of the linear model, usually clf for a classifier, reg for a regressor \n", " \"\"\"\n", " \n", " if feature_selector is not None:\n", " if isinstance(estimator,GridSearchCV) or isinstance(estimator,RandomizedSearchCV)\\\n", " or isinstance(estimator,HalvingGridSearchCV) or isinstance(estimator,HalvingRandomSearchCV):\n", " est=estimator.best_estimator_\n", " elif isinstance(estimator,Pipeline):\n", " est=estimator\n", " else:\n", " print(\"Either pipeline or gridsearch/randomsearch should be passes for estimator\")\n", " return\n", " \n", " selecteds=est[feature_selector].get_support()\n", " final_features=[x for e,x in enumerate(get_feature_names_from_columntransformer(preprocessor)) if e in np.argwhere(selecteds==True).ravel()]\n", " else:\n", " final_features=get_feature_names_from_columntransformer(preprocessor)\n", "\n", " importance=est[clfreg_name].coef_[0]\n", " plt.bar(final_features, importance)\n", " plt.xticks(rotation= 45,horizontalalignment=\"right\"); \n", "\n", "\n", "\n", "def gridsearch_to_df(searcher,topN=5):\n", " \"\"\"\n", " searcher: any of grid/randomized searcher objects or their halving versions\n", " \"\"\"\n", " cvresultdf = pd.DataFrame(searcher.cv_results_)\n", " cvresultdf = cvresultdf.sort_values(\"mean_test_score\", ascending=False)\n", " cols=[x for x in searcher.cv_results_.keys() if \"param_\" in x]+[\"mean_test_score\",\"std_test_score\"]\n", " return cvresultdf[cols].head(topN) \n", "\n", "\n", "def getAnotherEstimatorFromGridSearch(gs_object,estimator):\n", " cvres = gs_object.cv_results_\n", " cv_results = pd.DataFrame(cvres)\n", " cv_results[\"param_clf\"]=cv_results[\"param_clf\"].apply(lambda x:str(x).split('(')[0])\n", "\n", " dtc=cv_results[cv_results[\"param_clf\"]==estimator]\n", " return dtc.getRowOnAggregation_(\"mean_test_score\",\"max\")[\"params\"].values \n", "\n", "def cooksdistance(X,y,figsize=(8,6),ylim=0.5): \n", " model = sm.OLS(y,X)\n", " fitted = model.fit()\n", " # Cook's distance\n", " pr=X.shape[1]\n", " CD = 4.0/(X.shape[0]-pr-1)\n", " influence = fitted.get_influence()\n", " #c is the distance and p is p-value\n", " (c, p) = influence.cooks_distance\n", " plt.figure(figsize=figsize)\n", " plt.stem(np.arange(len(c)), c, markerfmt=\",\")\n", " plt.axhline(y=CD, color='r')\n", " plt.ylabel('Cook\\'s D')\n", " plt.xlabel('Observation Number')\n", " plt.ylim(0,ylim)\n", " plt.show();\n", "\n" ] } ], "source": [ "with io.open(\"/content/drive/MyDrive/Programming/PythonRocks/mypyext/ml.py\", \"r\", encoding='cp1254') as f:\n", " print(f.read())" ] }, { "cell_type": "markdown", "metadata": { "id": "suEJ8XztNP2O" }, "source": [ "## Yazma" ] }, { "cell_type": "code", "execution_count": 303, "metadata": { "id": "055w2MM7NP2O", "outputId": "8d6326fd-2706-42f4-a5e6-14a43b11e344", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "8" ] }, "metadata": {}, "execution_count": 303 } ], "source": [ "yenidosya=io.open(\"writetest.txt\",\"w\") #x\n", "yenidosya.write(\"merhaba\\n\")\n", "lines=[\"satır1\\n\",\"satır2\\n\"]\n", "yenidosya.writelines(lines)\n", "yenidosya.close()" ] }, { "cell_type": "code", "execution_count": 304, "metadata": { "id": "GUbenUslNP2O", "outputId": "801d967b-4cbb-4f9e-dfd6-cf42afa67d18", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "6" ] }, "metadata": {}, "execution_count": 304 } ], "source": [ "#varolana yaz, sonuna ekleme\n", "yenidosya=io.open(\"writetest.txt\",\"a\")\n", "yenidosya.write(\"\\nselam\")\n", "yenidosya.flush() #hemen yazsın. bunu kullanmazsak yaptığımız değişiklikleri hemen görmeyiz\n", "yenidosya.close()" ] }, { "cell_type": "code", "source": [ "!rm writetest.txt" ], "metadata": { "id": "6e04xrowTOeF" }, "execution_count": 305, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "lofzAC10NP2Q" }, "source": [ "# Veritabanı işlemleri" ] }, { "cell_type": "code", "execution_count": 306, "metadata": { "id": "EgfOzPiPNP2Q" }, "outputs": [], "source": [ "import sqlite3 as sql #python içinde otomatikman gelir" ] }, { "cell_type": "markdown", "metadata": { "id": "7vGExp6mNP2Q" }, "source": [ "sqlite sayfasından chinook databaseini indirin" ] }, { "cell_type": "code", "execution_count": 307, "metadata": { "id": "6pgtkIIlNP2R" }, "outputs": [], "source": [ "vt = sql.connect('/content/drive/MyDrive/Programming/PythonRocks/dataset/chinook.db')" ] }, { "cell_type": "code", "execution_count": 308, "metadata": { "id": "51kSF6MbNP2R" }, "outputs": [], "source": [ "cur=vt.cursor()" ] }, { "cell_type": "code", "execution_count": 309, "metadata": { "scrolled": true, "id": "QYENBSRZNP2R", "outputId": "0bbdea17-d1f4-4637-976b-dd02da428eeb", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "" ] }, "metadata": {}, "execution_count": 309 } ], "source": [ "cur.execute(\"select * from albums\")" ] }, { "cell_type": "code", "execution_count": 310, "metadata": { "id": "wIlYv6fENP2S", "outputId": "0abaa3e1-62da-4a27-f961-abd80f39e181", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[(1, 'For Those About To Rock We Salute You', 1),\n", " (2, 'Balls to the Wall', 2),\n", " (3, 'Restless and Wild', 2)]" ] }, "metadata": {}, "execution_count": 310 } ], "source": [ "cur.fetchmany(3)" ] }, { "cell_type": "code", "execution_count": 311, "metadata": { "id": "2vkd8fvdNP2S" }, "outputs": [], "source": [ "veriler = cur.fetchall()" ] }, { "cell_type": "code", "execution_count": 312, "metadata": { "scrolled": true, "id": "KpHtTp8GNP2S", "outputId": "fb30f204-9963-41be-b053-82ed1429d974", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "execute_result", "data": { "text/plain": [ "[(4, 'Let There Be Rock', 1),\n", " (5, 'Big Ones', 3),\n", " (6, 'Jagged Little Pill', 4),\n", " (7, 'Facelift', 5),\n", " (8, 'Warner 25 Anos', 6)]" ] }, "metadata": {}, "execution_count": 312 } ], "source": [ "veriler[:5] #ilk 3ünü çektiğimiz için 4ten devam ediyor" ] }, { "cell_type": "code", "execution_count": 313, "metadata": { "id": "bbmc2UcjNP2S" }, "outputs": [], "source": [ "vt.close()" ] }, { "cell_type": "markdown", "metadata": { "id": "XF2lNJ1jNP2S" }, "source": [ "

NOT:sqlite3 çok basit bir veritabanı olup, oracle veya sql server gibi güçlü veritabanlarını sorgulamak için sqlalchemy veya pyodbc gibi modülleri kullanırız ve buradan aldığmız datayı pandas ile işleyebiliriz. Bunun için benim github repomdaki Python Veri Analizi notebookuna bakmanızı tavsiye ederim.

" ] }, { "cell_type": "markdown", "metadata": { "id": "7yl4D60NNP2S" }, "source": [ "http://sqlitebrowser.org/. sitesi de incelenebilir" ] }, { "cell_type": "markdown", "metadata": { "id": "aWdQ3O35NP2S" }, "source": [ "# Classlar" ] }, { "cell_type": "markdown", "metadata": { "id": "dsnWXgT5NP2T" }, "source": [ "Python nesne yönelimli(oo) bir dildir ve tüm oo dillerde olduğu gibi sınıflar yaratılabilir. Örnek bir sınıf yaratımı aşağıdaki gibi olup detaylar için googlelamanızı rica ederim." ] }, { "cell_type": "code", "execution_count": 314, "metadata": { "id": "ISjW6xL4NP2T", "outputId": "3a6022fe-62c6-464f-e478-3f7c80b24c16", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "yeni araç hazır\n", "yeni araç hazır\n", "yeni araç hazır\n", "<__main__.Araba object at 0x7d45a4bfff70>\n", "çalışıyor\n", "durdu\n", "Mekanik\n", "Mekanik\n" ] } ], "source": [ "class Araba:\n", " aractipi=\"Mekanik\" #class seviyesinde, tüm Arabalar tarafından paylaşılan bir değer\n", " def __init__(self,model,marka,km):\n", " self.model=model\n", " self.marka=marka\n", " self.km=km\n", " print(\"yeni araç hazır\")\n", " def run(self):\n", " print(\"çalışıyor\")\n", " def stop(self):\n", " print(\"durdu\")\n", "\n", "bmw0=Araba(2011,\"bmw\",0)\n", "bmw1=Araba(2014,\"bmw\",0)\n", "audi=Araba(2011,\"audi\",0)\n", "print(bmw0)\n", "bmw0.run()\n", "bmw0.stop()\n", "print(bmw0.aractipi)\n", "print(audi.aractipi)" ] }, { "cell_type": "markdown", "metadata": { "id": "jy6MGCozNP2T" }, "source": [ "## Paralelleştirme" ] }, { "cell_type": "markdown", "metadata": { "id": "4vVeILX-NP2T" }, "source": [ "Özellikle analitik model kurma sırasında çok işimize yarayan bir olgudur. Bunun için ayrı bir notebook'um olacak. Önden araştırmak isteyenler şu kavramları araştırabilir. Multi-threading, multiprocessing, conccurency ve parallelism" ] }, { "cell_type": "markdown", "metadata": { "id": "fabSEm7ANP2T" }, "source": [ "# Verimlilik ve Diğer" ] }, { "cell_type": "markdown", "metadata": { "id": "ocn1iv8JNP2U" }, "source": [ "## debugging" ] }, { "cell_type": "code", "execution_count": 315, "metadata": { "scrolled": true, "id": "CDamCKWINP2U", "outputId": "ce10d6b7-bded-43af-80a1-84bda466c6ca", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stderr", "text": [ "\n", "PYDEV DEBUGGER WARNING:\n", "sys.settrace() should not be used when the debugger is being used.\n", "This may cause the debugger to stop working correctly.\n", "If this is needed, please check: \n", "http://pydev.blogspot.com/2007/06/why-cant-pydev-debugger-work-with.html\n", "to see how to restore the debug tracing back correctly.\n", "Call Location:\n", " File \"/usr/lib/python3.10/bdb.py\", line 336, in set_trace\n", " sys.settrace(self.trace_dispatch)\n", "\n" ] }, { "name": "stdout", "output_type": "stream", "text": [ "4\n", "--Call--\n", "> \u001b[0;32m/usr/local/lib/python3.10/dist-packages/IPython/core/displayhook.py\u001b[0m(252)\u001b[0;36m__call__\u001b[0;34m()\u001b[0m\n", "\u001b[0;32m 250 \u001b[0;31m \u001b[0msys\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstdout\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mflush\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0m\u001b[0;32m 251 \u001b[0;31m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0m\u001b[0;32m--> 252 \u001b[0;31m \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mresult\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0m\u001b[0;32m 253 \u001b[0;31m \"\"\"Printing with history cache management.\n", "\u001b[0m\u001b[0;32m 254 \u001b[0;31m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0m\n", "ipdb> c\n" ] }, { "output_type": "stream", "name": "stderr", "text": [ "\n", "PYDEV DEBUGGER WARNING:\n", "sys.settrace() should not be used when the debugger is being used.\n", "This may cause the debugger to stop working correctly.\n", "If this is needed, please check: \n", "http://pydev.blogspot.com/2007/06/why-cant-pydev-debugger-work-with.html\n", "to see how to restore the debug tracing back correctly.\n", "Call Location:\n", " File \"/usr/lib/python3.10/bdb.py\", line 347, in set_continue\n", " sys.settrace(None)\n", "\n" ] }, { "output_type": "stream", "name": "stdout", "text": [ "asda\n" ] } ], "source": [ "import pdb\n", "print(4)\n", "pdb.set_trace() #c devam, n:next gibi seçenekler var\n", "print(\"asda\")" ] }, { "cell_type": "markdown", "metadata": { "id": "won9XpBlNP2U" }, "source": [ "## memory yönetimi" ] }, { "cell_type": "code", "execution_count": 317, "metadata": { "scrolled": true, "id": "AdmijMKPNP2V", "outputId": "e654c22f-8181-4b11-b6fa-64b2e449a166", "colab": { "base_uri": "https://localhost:8080/" } }, "outputs": [ { "output_type": "stream", "name": "stdout", "text": [ "64\n", "88\n", "104\n" ] } ], "source": [ "import sys\n", "import array\n", "t=(1,2,3)\n", "l=[1,2,\"3\"]\n", "a=array.array(\"l\",[1,2,3])\n", "print(sys.getsizeof(t)) #immutabel olduğu için daha az\n", "print(sys.getsizeof(l)) #mutable olduğu için tupldan daha çok, içine farklı tipler alabileceğim için arraydan daha çok\n", "print(sys.getsizeof(a)) #eleman tipi belli olduğu için listten daha az" ] }, { "cell_type": "markdown", "metadata": { "id": "C0XtcQ6ONP2V" }, "source": [ "# Cheatsheet" ] }, { "cell_type": "markdown", "metadata": { "id": "UE-hIG00NP2V" }, "source": [ "![cheatsheet.png](cheatsheet.png)" ] }, { "cell_type": "markdown", "metadata": { "id": "1YeCwWllNP2V" }, "source": [ "# Kendinizi test edin" ] }, { "cell_type": "markdown", "metadata": { "id": "uj1XC9KjNP2V" }, "source": [ "Aşağıdaki adreslerden birinden challange sorularını görebilirsiniz.\n", "* https://mybinder.org/v2/gh/VolkiTheDreamer/PythonRocks/master (Interaktiftir, download etmenize gerek yok)\n", "* üstteki açılmazsa: https://nbviewer.org/github/VolkiTheDreamer/PythonRocks/blob/master/Python%20Challenges.ipynb\n" ] }, { "cell_type": "markdown", "metadata": { "id": "bI3tbqMJNP2V" }, "source": [ "Bunun dışında şu sitelerde de pratik yapma imkanı bulabilirsiniz.\n", "\n", "- https://www.w3resource.com/python-exercises/\n", "- https://www.practicepython.org/\n", "- https://www.w3schools.com/python/python_exercises.asp\n", "- https://pynative.com/python-exercises-with-solutions/" ] } ], "metadata": { "hide_input": false, "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.8.6" }, "toc": { "base_numbering": 1, "nav_menu": {}, "number_sections": true, "sideBar": true, "skip_h1_title": false, "title_cell": "Table of Contents", "title_sidebar": "Contents", "toc_cell": false, "toc_position": { "height": "708px", "left": "300px", "top": "148px", "width": "305.625px" }, "toc_section_display": true, "toc_window_display": true }, "varInspector": { "cols": { "lenName": 16, "lenType": 16, "lenVar": 40 }, "kernels_config": { "python": { "delete_cmd_postfix": "", "delete_cmd_prefix": "del ", "library": "var_list.py", "varRefreshCmd": "print(var_dic_list())" }, "r": { "delete_cmd_postfix": ") ", "delete_cmd_prefix": "rm(", "library": "var_list.r", "varRefreshCmd": "cat(var_dic_list()) " } }, "types_to_exclude": [ "module", "function", "builtin_function_or_method", "instance", "_Feature" ], "window_display": false }, "colab": { "provenance": [], "toc_visible": true, "include_colab_link": true }, "widgets": { "application/vnd.jupyter.widget-state+json": { "751edc7876624c858be3920a656bbe5a": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_a17d5706940d471c8def62d24b380451", "IPY_MODEL_94759083162b4ba7882beb31f5f5c0e6", "IPY_MODEL_da19b67ccfca40f0ac6fea0079279b45" ], "layout": "IPY_MODEL_451f673b411e45c89ba06581e24f3632" } }, "a17d5706940d471c8def62d24b380451": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_34289f2781b94924ab52dcc7accc4f9b", "placeholder": "​", "style": "IPY_MODEL_1178361d7b984b039fd0e5ee6a569adb", "value": "1st loop: 100%" } }, "94759083162b4ba7882beb31f5f5c0e6": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_125bc33900574ed692c44040871f04d0", "max": 3, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_c26eb70f93b248e2b78df67a5b6ccc65", "value": 3 } }, "da19b67ccfca40f0ac6fea0079279b45": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_13308604b83b4ff881bf2e86f199a654", "placeholder": "​", "style": "IPY_MODEL_286b1c469c4f48c9b4dca098d506e0e2", "value": " 3/3 [00:03<00:00,  1.08s/it]" } }, "451f673b411e45c89ba06581e24f3632": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "34289f2781b94924ab52dcc7accc4f9b": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "1178361d7b984b039fd0e5ee6a569adb": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "125bc33900574ed692c44040871f04d0": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "c26eb70f93b248e2b78df67a5b6ccc65": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "13308604b83b4ff881bf2e86f199a654": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "286b1c469c4f48c9b4dca098d506e0e2": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "4b45e53206ac4335ad64c1bc76cf0a54": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_94b5dcb00309447db4caf1ca5f2bca6c", "IPY_MODEL_f34d953ef0f04222800959bad565983a", "IPY_MODEL_4a35b3bf482b483bbe7f3979968b2b57" ], "layout": "IPY_MODEL_f21bf8ef6c2543e5b9bd3a2006f37d99" } }, "94b5dcb00309447db4caf1ca5f2bca6c": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_898d07425ae6424d9b373bcb23388625", "placeholder": "​", "style": "IPY_MODEL_2ce64cb4ef464074a58d8d3985b7a4c3", "value": "2nd loop: 100%" } }, "f34d953ef0f04222800959bad565983a": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_a30f9a14b37949aea2fe0577940e22d3", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_803c924d944242399095d29937f7e046", "value": 100 } }, "4a35b3bf482b483bbe7f3979968b2b57": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_bd81728b56694c7493e07276209917a8", "placeholder": "​", "style": "IPY_MODEL_e1a40e5aab3f40ebbb01cd40c1994a8b", "value": " 100/100 [00:01<00:00, 97.19it/s]" } }, "f21bf8ef6c2543e5b9bd3a2006f37d99": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "898d07425ae6424d9b373bcb23388625": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "2ce64cb4ef464074a58d8d3985b7a4c3": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "a30f9a14b37949aea2fe0577940e22d3": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "803c924d944242399095d29937f7e046": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "bd81728b56694c7493e07276209917a8": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "e1a40e5aab3f40ebbb01cd40c1994a8b": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "55a59a782aa84a98a6ae9a131707e7e4": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_a2adb592ff3245869a0d6379148a97fa", "IPY_MODEL_d9fb51af123045bfb01c0ca4ff71aadf", "IPY_MODEL_f057770d640d4d768887b58b24a05698" ], "layout": "IPY_MODEL_b2b1f12e421249369d42dee4ee11ff55" } }, "a2adb592ff3245869a0d6379148a97fa": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_c017e47d80f04575872ee21fa7dc9271", "placeholder": "​", "style": "IPY_MODEL_1f31528beea8479db1929519dc36ebe0", "value": "2nd loop: 100%" } }, "d9fb51af123045bfb01c0ca4ff71aadf": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_ff25dde586244614852fb29ffd51dac9", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_2ad95d0a26034b62ad7a0941045a8bd6", "value": 100 } }, "f057770d640d4d768887b58b24a05698": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_5dc1487f2b6a4a339d103355b6209569", "placeholder": "​", "style": "IPY_MODEL_2193d83b7019419c86f9915866b79247", "value": " 100/100 [00:01<00:00, 94.61it/s]" } }, "b2b1f12e421249369d42dee4ee11ff55": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "c017e47d80f04575872ee21fa7dc9271": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "1f31528beea8479db1929519dc36ebe0": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "ff25dde586244614852fb29ffd51dac9": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "2ad95d0a26034b62ad7a0941045a8bd6": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "5dc1487f2b6a4a339d103355b6209569": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "2193d83b7019419c86f9915866b79247": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "a57d90da18644950b9ffc8517fe1df7b": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_da5f50d542c14d8f898c9f76abd9709d", "IPY_MODEL_8e86a15ad03845ed93fc85c7b82487d4", "IPY_MODEL_0aa16e4c1d1d4059841e36d8b325971f" ], "layout": "IPY_MODEL_9fd3dc999c6d4270a9ecfe2d8e8f5e1d" } }, "da5f50d542c14d8f898c9f76abd9709d": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_6ec9be16d0354a8d87c177f2f68c49da", "placeholder": "​", "style": "IPY_MODEL_10a3331d6fec4345a45b8f8f9d0a8146", "value": "2nd loop: 100%" } }, "8e86a15ad03845ed93fc85c7b82487d4": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_f125a24c6cf347a3b296a2906556be7a", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_e618cb21d1d6458ca0374e8618dd4ca8", "value": 100 } }, "0aa16e4c1d1d4059841e36d8b325971f": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_2ddf420ed3dc4d429495f5ba7f922956", "placeholder": "​", "style": "IPY_MODEL_1516a50c3d4342f693aefe40460d6dd2", "value": " 100/100 [00:01<00:00, 95.69it/s]" } }, "9fd3dc999c6d4270a9ecfe2d8e8f5e1d": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "6ec9be16d0354a8d87c177f2f68c49da": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "10a3331d6fec4345a45b8f8f9d0a8146": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "f125a24c6cf347a3b296a2906556be7a": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "e618cb21d1d6458ca0374e8618dd4ca8": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "2ddf420ed3dc4d429495f5ba7f922956": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "1516a50c3d4342f693aefe40460d6dd2": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "2a723646e62b4dd0b4f147b66b704a02": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_7f56935b36514d2980be356a24f24b84", "IPY_MODEL_dfcfb947b6824327a3aeeb6461e06165", "IPY_MODEL_8118d9ea4ff74f60819e662d8d5df91f" ], "layout": "IPY_MODEL_8994340799334930b1cd7409ae0b0727" } }, "7f56935b36514d2980be356a24f24b84": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_90169b29d6014841a489708e49a74083", "placeholder": "​", "style": "IPY_MODEL_0776cd338bc1482f965b660491c6afd0", "value": "1st loop: 100%" } }, "dfcfb947b6824327a3aeeb6461e06165": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_e0cd072898dd47c5a217204603ad31c7", "max": 4, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_75b1e79b2bfa42f0a92507207515c487", "value": 4 } }, "8118d9ea4ff74f60819e662d8d5df91f": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_b474aa16bfd54d168f294424bfee7fe8", "placeholder": "​", "style": "IPY_MODEL_a340f22aac384496a41d9a645ffcb7b7", "value": " 4/4 [00:04<00:00,  1.06s/it]" } }, "8994340799334930b1cd7409ae0b0727": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "90169b29d6014841a489708e49a74083": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "0776cd338bc1482f965b660491c6afd0": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "e0cd072898dd47c5a217204603ad31c7": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "75b1e79b2bfa42f0a92507207515c487": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "b474aa16bfd54d168f294424bfee7fe8": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "a340f22aac384496a41d9a645ffcb7b7": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "46b5e5dda0304f758c60b6f94051325f": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_d0df97328d7b433dbb72b61b9743a34c", "IPY_MODEL_8268fc90ebd94eab8dddfc11e1bb1aa2", "IPY_MODEL_220049b6b28d405b9d1010805501f50f" ], "layout": "IPY_MODEL_dc194839fc494e5d925d26561f9b32e3" } }, "d0df97328d7b433dbb72b61b9743a34c": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_2014f467dc8249e09936b3dff8a4e95e", "placeholder": "​", "style": "IPY_MODEL_10abace2675141db9dcdf6ed9dd7a218", "value": "2nd loop: 100%" } }, "8268fc90ebd94eab8dddfc11e1bb1aa2": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_ef47ccd577ea49a98c99ab3721c3a7f7", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_e7075953580844248beb6a73c7b3bc36", "value": 100 } }, "220049b6b28d405b9d1010805501f50f": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_3dbd6933866c45e7b71f0e7c9b22ad02", "placeholder": "​", "style": "IPY_MODEL_03914bef2ebb436ab254aa4f315009e1", "value": " 100/100 [00:01<00:00, 96.32it/s]" } }, "dc194839fc494e5d925d26561f9b32e3": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "2014f467dc8249e09936b3dff8a4e95e": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "10abace2675141db9dcdf6ed9dd7a218": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "ef47ccd577ea49a98c99ab3721c3a7f7": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "e7075953580844248beb6a73c7b3bc36": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "3dbd6933866c45e7b71f0e7c9b22ad02": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "03914bef2ebb436ab254aa4f315009e1": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "2f7c7946c1fc40388172d25cd16d3f7e": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_c2bfc664050b47d888888b8bb0fc08ef", "IPY_MODEL_8ebdf5f0455c489ca970872f0670f1ee", "IPY_MODEL_18c4539041eb48e1a6fc3be4a251eb10" ], "layout": "IPY_MODEL_1f77f1cc085d423a9580200e96c34758" } }, "c2bfc664050b47d888888b8bb0fc08ef": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_9198335e467b43f3b8690c5bbaf58618", "placeholder": "​", "style": "IPY_MODEL_5f6ad924e3dd45d5821e33dbc0249f1c", "value": "2nd loop: 100%" } }, "8ebdf5f0455c489ca970872f0670f1ee": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_71a02681e9264458b860ecca3fb7e69c", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_a59b6f2054dc4e948180bfd09d0ba00b", "value": 100 } }, "18c4539041eb48e1a6fc3be4a251eb10": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_1c2a20f640f242feb3e54612df97f56a", "placeholder": "​", "style": "IPY_MODEL_e3e89e68dc3d4144a9cf20ad8257a9d4", "value": " 100/100 [00:01<00:00, 95.50it/s]" } }, "1f77f1cc085d423a9580200e96c34758": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "9198335e467b43f3b8690c5bbaf58618": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "5f6ad924e3dd45d5821e33dbc0249f1c": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "71a02681e9264458b860ecca3fb7e69c": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "a59b6f2054dc4e948180bfd09d0ba00b": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "1c2a20f640f242feb3e54612df97f56a": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "e3e89e68dc3d4144a9cf20ad8257a9d4": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "4d288466b05f48728173f1351087d17c": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_c4560d87d77a44ed9b5ebdbf994375c6", "IPY_MODEL_a9ad6adbb75447a6884c12a8e7ced40a", "IPY_MODEL_02a9a607bc4041f4ac417118d866b608" ], "layout": "IPY_MODEL_19f3115c55c24bef93ae99e8c5c45529" } }, "c4560d87d77a44ed9b5ebdbf994375c6": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_d6b6d63fe6ed4cb58659ae2711c5a94f", "placeholder": "​", "style": "IPY_MODEL_d4e641c56552460c87905887e70829c2", "value": "2nd loop: 100%" } }, "a9ad6adbb75447a6884c12a8e7ced40a": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_385c2a546fc244f688bfdf32047b2ee3", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_a465664b6da74a9b9913164c05890785", "value": 100 } }, "02a9a607bc4041f4ac417118d866b608": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_384f5336a7f949c586744448645f05df", "placeholder": "​", "style": "IPY_MODEL_b7454e3fc74b4b00b96f407748ec88f2", "value": " 100/100 [00:01<00:00, 97.21it/s]" } }, "19f3115c55c24bef93ae99e8c5c45529": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "d6b6d63fe6ed4cb58659ae2711c5a94f": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "d4e641c56552460c87905887e70829c2": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "385c2a546fc244f688bfdf32047b2ee3": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "a465664b6da74a9b9913164c05890785": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "384f5336a7f949c586744448645f05df": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "b7454e3fc74b4b00b96f407748ec88f2": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "9677ba9be9d143b2930801e7b88f38d3": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_d0007ff716e04689855fee5ee46f5d11", "IPY_MODEL_a622553bbe27473dbc5c5b98e9ee7fc6", "IPY_MODEL_f9876579fc9f4273aa4666944675c22a" ], "layout": "IPY_MODEL_ab7d4ac726f34d348159d82b8cceb6e1" } }, "d0007ff716e04689855fee5ee46f5d11": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_29e2fa26a1994d57a2c04a8e2dc1c1af", "placeholder": "​", "style": "IPY_MODEL_2940b68710a34f449e8c37f4fff9b8fc", "value": "2nd loop: 100%" } }, "a622553bbe27473dbc5c5b98e9ee7fc6": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_7ec17ed3d1c148b0920358d15a61c3d3", "max": 100, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_f8aab6bc3841431e89899f78a149de09", "value": 100 } }, "f9876579fc9f4273aa4666944675c22a": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_077e73ca35334ea993803d0184fa8259", "placeholder": "​", "style": "IPY_MODEL_c99f9790d8ab4455b7cc4cc0761fbe15", "value": " 100/100 [00:01<00:00, 97.15it/s]" } }, "ab7d4ac726f34d348159d82b8cceb6e1": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "29e2fa26a1994d57a2c04a8e2dc1c1af": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "2940b68710a34f449e8c37f4fff9b8fc": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "7ec17ed3d1c148b0920358d15a61c3d3": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "f8aab6bc3841431e89899f78a149de09": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "077e73ca35334ea993803d0184fa8259": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "c99f9790d8ab4455b7cc4cc0761fbe15": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "d9b31269f6a44179ae92bf432bd54c5b": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_91af54bc0c9e49629a65cacf67bda104", "IPY_MODEL_b21f17e916c94580b7cfd25805d26323", "IPY_MODEL_3162987da282497bb2f2821cc8f292c7" ], "layout": "IPY_MODEL_ab3eaed1d20547628991f415d5adad0c" } }, "91af54bc0c9e49629a65cacf67bda104": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_545c51443b2a443d9d37eb10b18d35cc", "placeholder": "​", "style": "IPY_MODEL_b32c0170cc1a4dff91ff074d123f9d52", "value": "100%" } }, "b21f17e916c94580b7cfd25805d26323": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_f0001ddf3d4a45d2869803414894c983", "max": 10, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_e73c46a77b91498980a942d778d961ba", "value": 10 } }, "3162987da282497bb2f2821cc8f292c7": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_dbd2d97b660d4c9d9de92471b1796331", "placeholder": "​", "style": "IPY_MODEL_1db4bc7a804e41b7838bc069695eddf5", "value": " 10/10 [00:05<00:00,  1.99it/s]" } }, "ab3eaed1d20547628991f415d5adad0c": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "545c51443b2a443d9d37eb10b18d35cc": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "b32c0170cc1a4dff91ff074d123f9d52": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "f0001ddf3d4a45d2869803414894c983": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "e73c46a77b91498980a942d778d961ba": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "dbd2d97b660d4c9d9de92471b1796331": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "1db4bc7a804e41b7838bc069695eddf5": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "6112246249584fb2a73cbd6e5086c89a": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_f0f7078f01c1405ab75ef477a106cb36", "IPY_MODEL_bf947e1161974b07af1bc216fa50b2aa", "IPY_MODEL_ce038aec570a478c8fd770a7f074722f" ], "layout": "IPY_MODEL_44c1cbfc30b64530a84c464ad263e8df" } }, "f0f7078f01c1405ab75ef477a106cb36": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_b00f63067158418db9527771958313c4", "placeholder": "​", "style": "IPY_MODEL_c337f94c20f140cab906d51a2890da49", "value": "Loop 1: 100%" } }, "bf947e1161974b07af1bc216fa50b2aa": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_40af719cb62c49c2a1632876b2ae865f", "max": 2, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_034ed767050d41c7937b0476bfdb3c87", "value": 2 } }, "ce038aec570a478c8fd770a7f074722f": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_5e1bf1ec9d6048e2b553a72bb3777b0a", "placeholder": "​", "style": "IPY_MODEL_58cdd4903a62471d9ecec9cf40fc0d7a", "value": " 2/2 [00:05<00:00,  2.55s/it]" } }, "44c1cbfc30b64530a84c464ad263e8df": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "b00f63067158418db9527771958313c4": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "c337f94c20f140cab906d51a2890da49": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "40af719cb62c49c2a1632876b2ae865f": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "034ed767050d41c7937b0476bfdb3c87": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "5e1bf1ec9d6048e2b553a72bb3777b0a": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "58cdd4903a62471d9ecec9cf40fc0d7a": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "7ec0f3f7a707490da8becdb283ad3b9f": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_3cd168f631ae4ad7be7d36c0ae813c73", "IPY_MODEL_78903c3560be4623acce5faf7d4a3ad8", "IPY_MODEL_3280d0e326ad4a779126819711c92e5c" ], "layout": "IPY_MODEL_e2d46d21e9534ba49d5bee5f8aa3050e" } }, "3cd168f631ae4ad7be7d36c0ae813c73": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_d76b0dac3b4c4b358846f5600e439e85", "placeholder": "​", "style": "IPY_MODEL_77a56e87b70e4d7aa22ca1cf7e575c04", "value": "Loop 2: 100%" } }, "78903c3560be4623acce5faf7d4a3ad8": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_ebdc3f6de85c4b0282da3334f73cfabc", "max": 5, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_276f4f8d45ed4f568c08093803d3ae50", "value": 5 } }, "3280d0e326ad4a779126819711c92e5c": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_2bf2bbe865c14190b24c1c0e566d4044", "placeholder": "​", "style": "IPY_MODEL_c2d09620e1e447988e2136a493af25c3", "value": " 5/5 [00:02<00:00,  1.98it/s]" } }, "e2d46d21e9534ba49d5bee5f8aa3050e": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "d76b0dac3b4c4b358846f5600e439e85": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "77a56e87b70e4d7aa22ca1cf7e575c04": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "ebdc3f6de85c4b0282da3334f73cfabc": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "276f4f8d45ed4f568c08093803d3ae50": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "2bf2bbe865c14190b24c1c0e566d4044": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "c2d09620e1e447988e2136a493af25c3": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "3ebff4dd167448a4bce6f6bf21760c1e": { "model_module": "@jupyter-widgets/controls", "model_name": "HBoxModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HBoxModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HBoxView", "box_style": "", "children": [ "IPY_MODEL_e8274af5bb9944bda83685457191eed5", "IPY_MODEL_0904a06cda6f491c943416e11ad262ae", "IPY_MODEL_9e597674145246fba1e2813aa5722ea7" ], "layout": "IPY_MODEL_631ecaafa15d44d6b45a0182f5427e29" } }, "e8274af5bb9944bda83685457191eed5": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_a7afbf7a190d412a8a1531576e84383f", "placeholder": "​", "style": "IPY_MODEL_9af068e5e72743dcbc18ed9f6dde794e", "value": "Loop 2: 100%" } }, "0904a06cda6f491c943416e11ad262ae": { "model_module": "@jupyter-widgets/controls", "model_name": "FloatProgressModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "FloatProgressModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "ProgressView", "bar_style": "success", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_a0eb297817774dd8a45e506109c068cd", "max": 5, "min": 0, "orientation": "horizontal", "style": "IPY_MODEL_cf27a49e481e47048174be88277fe3be", "value": 5 } }, "9e597674145246fba1e2813aa5722ea7": { "model_module": "@jupyter-widgets/controls", "model_name": "HTMLModel", "model_module_version": "1.5.0", "state": { "_dom_classes": [], "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "HTMLModel", "_view_count": null, "_view_module": "@jupyter-widgets/controls", "_view_module_version": "1.5.0", "_view_name": "HTMLView", "description": "", "description_tooltip": null, "layout": "IPY_MODEL_313edfa26f8f43a6835dc5eeb390c152", "placeholder": "​", "style": "IPY_MODEL_a914c7dd6ef64656a6ca0287af2b6c36", "value": " 5/5 [00:02<00:00,  1.99it/s]" } }, "631ecaafa15d44d6b45a0182f5427e29": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "a7afbf7a190d412a8a1531576e84383f": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "9af068e5e72743dcbc18ed9f6dde794e": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } }, "a0eb297817774dd8a45e506109c068cd": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "cf27a49e481e47048174be88277fe3be": { "model_module": "@jupyter-widgets/controls", "model_name": "ProgressStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "ProgressStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "bar_color": null, "description_width": "" } }, "313edfa26f8f43a6835dc5eeb390c152": { "model_module": "@jupyter-widgets/base", "model_name": "LayoutModel", "model_module_version": "1.2.0", "state": { "_model_module": "@jupyter-widgets/base", "_model_module_version": "1.2.0", "_model_name": "LayoutModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "LayoutView", "align_content": null, "align_items": null, "align_self": null, "border": null, "bottom": null, "display": null, "flex": null, "flex_flow": null, "grid_area": null, "grid_auto_columns": null, "grid_auto_flow": null, "grid_auto_rows": null, "grid_column": null, "grid_gap": null, "grid_row": null, "grid_template_areas": null, "grid_template_columns": null, "grid_template_rows": null, "height": null, "justify_content": null, "justify_items": null, "left": null, "margin": null, "max_height": null, "max_width": null, "min_height": null, "min_width": null, "object_fit": null, "object_position": null, "order": null, "overflow": null, "overflow_x": null, "overflow_y": null, "padding": null, "right": null, "top": null, "visibility": null, "width": null } }, "a914c7dd6ef64656a6ca0287af2b6c36": { "model_module": "@jupyter-widgets/controls", "model_name": "DescriptionStyleModel", "model_module_version": "1.5.0", "state": { "_model_module": "@jupyter-widgets/controls", "_model_module_version": "1.5.0", "_model_name": "DescriptionStyleModel", "_view_count": null, "_view_module": "@jupyter-widgets/base", "_view_module_version": "1.2.0", "_view_name": "StyleView", "description_width": "" } } } } }, "nbformat": 4, "nbformat_minor": 0 }