<p>Sponsored by Datadog: <a href="http://pythonbytes.fm/datadog"><strong>pythonbytes.fm/datadog</strong></a></p> <p>Special Guest: <a href="https://twitter.com/__mharrison__"><strong>Matt Harrison</strong></a></p> <p><strong>Topic #0: Quick chat about COVID 19.</strong></p> <ul> <li>What does your world look like?</li> <li>Amusing to see news channels, daily shows, etc, learning what we podcasters have figured out years ago</li> </ul> <p><strong>Brian #1:</strong> <a href="https://medium.com/better-programming/dictionary-merging-and-updating-in-python-3-9-4ac67c667ce"><strong>Dictionary Merging and Updating in Python 3.9</strong></a></p> <ul> <li>Yong Cui, Ph.D.</li> <li>Python 3.9, scheduled for Oct release, will introduce new merge <code>(|)</code> and update <code>(|=)</code> operators, a.k.a. union operators</li> <li>Available in <a href="https://www.python.org/downloads/release/python-390a5/">alpha 4 and later</a></li> <li>see also <a href="https://www.python.org/dev/peps/pep-0584/">pep 584</a></li> </ul> <pre><code> # merge d1 = {'a': 1, 'b': 2} d2 = {'c': 3, 'd': 4} d3 = d1 | d2 # d3 is now {'a': 1, 'b': 2, 'c': 3, 'd': 4} # update d1 = {'a': 1, 'b': 2} d1 |= {'c': 3, 'd': 4} # d1 is now {'a': 1, 'b': 2, 'c': 3, 'd': 4} # last one wins if contention for both | and |= d1 = {'a': 1, 'b': 2} d1 |= {'a': 10, 'c': 3, 'd': 4} # d1 is now {'a': 10, 'b': 2, 'c': 3, 'd': 4} </code></pre> <p><strong>Matt #2:</strong> <a href="https://github.com/btwael/superstring.py"><strong>superstring</strong></a></p> <ul> <li>An efficient library for heavy-text manipulation in Python, that achieves a remarkable memory and CPU optimization.</li> <li>Uses Rope (data structure) and optimization techniques.</li> <li>Performance comparisons for 50,000 char text <ul> <li>memory: 1/20th</li> <li>speed: 1/5th</li> </ul></li> <li>Features <ul> <li>Fast and Memory-optimized</li> <li>Rich API <ul> <li>concatenation (a + b)</li> <li>len() and .length()</li> <li>indexing</li> <li>slicing</li> <li>strip</li> <li>lower</li> <li>upper</li> </ul></li> </ul></li> <li>Similar functionalities to python built-in string</li> <li>Easy to embed and use.</li> <li>I wonder if any of these optimizations could be brought into CPython</li> <li>Beware, it’s lacking tests</li> </ul> <p><strong>Michael #3:</strong> <a href="https://pyfound.blogspot.com/2020/03/new-pip-resolver-to-roll-out-this-year.html"><strong>New pip resolver to roll out this year</strong></a></p> <ul> <li>via PyCoders</li> <li>The developers of pip are in the process of developing a new resolver for pip (as <a href="https://pyfound.blogspot.com/2019/12/moss-czi-support-pip.html">announced on the PSF blog</a> last year).</li> <li>As part of that work, there will be some major changes to how pip determines what to install, based on package requirements.</li> <li>What will change: <ul> <li>It will <strong>reduce inconsistency</strong>: it will <em>no longer install a combination of packages that is mutually inconsistent</em>.</li> <li>It will be <strong>stricter</strong> - if you ask pip to install two packages with incompatible requirements, it will refuse (rather than installing a broken combination, like it does now).</li> </ul></li> <li>What you can do to help <ul> <li>First and most fundamentally, <a href="https://bit.ly/pip-ux-studies">please help us understand how you use pip by</a> <a href="https://bit.ly/pip-ux-studies"><strong>talking with our user experience researchers</strong></a>.</li> <li>Even before we release the new resolver as a beta, you can help by <strong>running</strong> <code>**pip check**</code> <strong>on your current environment</strong>.</li> <li>Please make time to <strong><em>test</em></strong> <strong>the new version of pip, probably in May.</strong></li> <li><strong>Spread the word!</strong></li> <li>And if you develop or support a tool that wraps pip or uses it to deliver part of your functionality, please make time to <strong>test your integration with our beta in May</strong></li> </ul></li> </ul> <p><strong>Matt</strong> <strong>#4:</strong> <a href="https://www.kaggle.com/saga21/covid-global-forecast-sir-model-ml-regressions"><strong>Covid-19 Data</strong></a></p> <ul> <li>Think global act local</li> <li>Problem - No local data</li> <li>Made my own plots - current status no predictions</li> <li>ML works ok for basic model</li> <li>Implementing SIR Model with ordinary differential equations <strong>scipy odeint function</strong> </li> </ul> <p><strong>Brian #5:</strong> <a href="https://blog.carlmjohnson.net/post/2020/python-square-of-opposition/"><strong>Why does all() return True if the iterable is empty?</strong></a></p> <ul> <li>Carl Johnson</li> <li>Q: “Why does <code>all()</code> return <code>True</code> if the iterable is empty? Shouldn’t it return <code>False</code> just like <code>if my_list:</code>would evaluate to <code>False</code> if the list is empty? What’s the thinking behind it returning <code>True</code>?”</li> <li>Lesson 1: "… basically doesn’t matter. The Python core team chose to make <code>all([])</code>return <code>True</code>, and whatever their reasons, you can program your way around by adding wrapper functions or <code>if</code> tests. ”</li> <li>Lesson 2: “all unicorns are blue”</li> <li>Lesson 3: “This is literally a 2,500 year old debate in philosophy. The ancients thought “all unicorns are blue” should be false because there are no unicorns, but modern logic says it is true because there are no unicorns that aren’t blue. Python is just siding with modern predicate logic, but your intuition is also quite common and was the orthodox position until the last few hundred years.”</li> <li>Blog post goes into teaching about predicate logic, Socrates, Aristotelean syllogisms, and such.</li> <li>And, really, no answer to why. But now, I’ll never forget that <code>all([]) == True</code>.</li> </ul> <p><strong>Michael #6:</strong> <a href="https://github.com/CFMTech/pytest-monitor"><strong>pytest-monitor</strong></a></p> <ul> <li>written by Jean-Sébastien Dieu</li> <li>pytest plugin for analyzing resource usage during test sessions</li> <li>Analyze your resources consumption through test functions: <ul> <li>memory consumption</li> <li>time duration</li> <li>CPU usage</li> </ul></li> <li>Keep a history of your resource consumption measurements.</li> <li>Compare how your code behaves between different environments.</li> <li>Usage: Simply run <em>pytest</em> as usual: <em>pytest-monitor</em> is active by default as soon as it is installed. </li> <li>After running your first session, a .pymon sqlite database will be accessible in the directory where pytest was run.</li> <li>You will need a valid Python 3.5+ interpreter. To get measures, we rely on: <ul> <li><em>psutil</em> to extract CPU usage</li> <li><em>memory_profiler</em> to collect memory usage</li> <li>and <em>pytest</em> (obviously!)</li> </ul></li> </ul> <p>Extras:</p> <p>Michael:</p> <ul> <li><code>switchlang</code> is now <a href="https://pypi.org/project/switchlang/"><strong>on pypi</strong></a> <strong>:</strong> <code>pip install switchlang</code></li> <li><code>markdown-subtemplate</code> is now <a href="https://pypi.org/project/markdown-subtemplate/"><strong>on pypi</strong></a>: <code>pip install markdown-subtemplate</code></li> </ul> <p>Joke:</p> <p>Light timer fix: <a href="https://twitter.com/Sarcastic_Pharm/status/1238060786658009089">https://twitter.com/Sarcastic_Pharm/status/1238060786658009089</a></p>
from Planet Python
via read more
Subscribe to:
Post Comments (Atom)
TestDriven.io: Working with Static and Media Files in Django
This article looks at how to work with static and media files in a Django project, locally and in production. from Planet Python via read...
-
Graph traversal algorithms are used to perform various operations on a graph data structure. In this article, we will use the breadth-first ...
-
Podcasts are a great way to immerse yourself in an industry, especially when it comes to data science. The field moves extremely quickly, an...
-
In an earlier tutorial we've already covered how to open dialog windows. These are special windows which (by default) grab the focus o...
No comments:
Post a Comment