Python Daily
2.57K subscribers
1.48K photos
53 videos
2 files
38.9K links
Daily Python News
Question, Tips and Tricks, Best Practices on Python Programming Language
Find more reddit channels over at @r_channels
Download Telegram
[AF] How to sort posts more efficiently?

Hi, so I've been working on a reddit clone, for practice, and was wondering how to sort through posts more efficiently. Here is the code I have now to display posts on the main page:

def index():
posts = Post.query.all()
for post in posts:
post.set_hotness()
posts = Post.query.order_by(Post.hotness).all()
return render_template('index.html', title='Dopenet: You can do anything', posts=posts )

The set_hotness() function mentioned here is in the Posts table, which can be found [here](https://github.com/ModoUnreal/dopenet/blob/master/app/models.py).

I know my method of sorting through posts is highly inefficient and not scalable.

What am I doing wrong and how can I fix it?

/r/flask
https://redd.it/8exlzm
[AF] Can't run hello world app with Flask, UnicodeDecodeError

I'm trying to run simple hello world flask app but sockets throws an error on Windows 10, Python 3.6.4

File "D:\Python\Python36-32\lib\socket.py", line 673, in getfqdn:
hostname, aliases, ipaddrs = gethostbyaddr(name)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xab in position 80: invalid start byte
I know I could hack some code in the source of socket.py but I don't want to do that yet. My hostname is "Pitku" so I don't know what text/character is causing the error. Have already tried changing Code Pages but none have worked.

Is there any way to backtrace/fix this error?

/r/flask
https://redd.it/8eeb94
Learning Python before proceeding to Django?

How much Python should I need to learn before I proceed to learning Django?

/r/djangolearning
https://redd.it/8eyuo9
package of the day: tqdm

hello and welcome to package of the day, the show where i type a few lines about a package i quite like and would be of use to programmers in a wide variety of contexts

today's package is called "tqdm"

A fast, extensible progress bar for Python and CLI

have you ever written a for loop that iterates over many variables and takes a long time to run?

to track its progress did you just add a print statement inside the loop indicating how far or which variable you're on, producing hundreds if not thousands of lines of text you only look at sparingly?

now you can do better. just import tqdm: `from tqdm import tqdm`

and wrap the structure you're for-ing in the tqdm() function like so: `for i in tqdm(range(10000)):`

now when you run your code, a dynamic progress bar like this one will automatically be generated when you start your loop:

`76%|████████████████████████████ | 7568/10000 [00:33<00:10, 229.00it/s]`

not only will it show you your progress; it'll provide you some simple metrics about how long the loop is taking and will take

try tqdm today!

/r/Python
https://redd.it/8f5wo3
Is there any jupyter extension to search into jupyter directory by file contents?

I have tons .ipynb files.I want to search and filter by jupyter file contents. Hello everyone.I have tons .ipynb files.I want to search and filter by jupyter file contents. I do some search on google and find jupyter-tree-filter which adds a search box on your jupyter directory and filter files by filename, not by file contents.Is there any jupyter extension to search jupyter file contents?

/r/JupyterNotebooks
https://redd.it/8f5okb
How can I use Python to automate mass-printing in my office?

Hi all! Like many of you, I have an office job with a lot of repetitive daily tasks.

I work for a travel company, and I've recently been put in charge of admin duties which involve physically printing out customized cover letters and selected information sheets (dependent on which tour / location we're sending clients to, which airline they're flying with, transfer companies etc) to mail to our clients pre-departure. I have to spend a lot of time selecting the right documents to send them, and it's really eating up my time when this isn't really my job role.

The problem is, no one else is going to do it, so I'd love to find a way to automate it so I can free up time to do my actual job.

My current theory at the moment would be a basic spreadsheet with boolean values for each airlines, tour operators etc, cover letters, then make a basic loop that grabs the client name, customizes and populates the PDFs and then does a batch print job.

Can anyone suggest a better way to do this, or specific libraries to use, etc? Would love to hear your suggestions :)

Thanks all, and have a good day!

/r/Python
https://redd.it/8fa955
sqlalchemy query as dict

Is there a simple way to return the query result as a dict without much hassle?
I have this query: result = SomeModel.query.with_entities(....).filter(...).all(). With this I get the desired fields as a list. Now I would like to get them with their corresponding column name. Is it possible to do this in the query directly without additional computing? I have tried with label() and with_labels() but with no luck.

/r/flask
https://redd.it/8f3bom
Strong password and passphrase generator package with entropy calculation

Hey, longtime lurker here. Finally decided to give developing new packages a shot and released a package for generating cryptographically strong passwords and passphrases. I still have a lot to learn so I appreciate any tips or comments on how to improve!

[SPass](https://github.com/Tauag/spass)

/r/Python
https://redd.it/8fby9a
Someone is scraping my website, what can I do to automatically block them?

I run a real estate listings site and there is someone scraping the records one-by-one. I track each listing impression and I can see which IP addresses are scraping the data. I've been blocking the IP's but the scraper is now using 3+ IP addresses at a time to scrape.

What can I do to prevent the mad scrapes? Is there some way for my server to automatically ban an IP address if it hits too many impressions during a period of time?

/r/django
https://redd.it/8fcq91
Python Anywhere Blocked in Russia
http://blog.pythonanywhere.com/163/

/r/Python
https://redd.it/8fdf9d
SQLAlchemy vs PostgreSQL Functions

Hey guys, we're using heavily PostgreSQL (we let it handle all business logic, mapping, etc.). We use Flask only to handle requests, call queries on the DB and then respond back the return from the Database.
Now a problem is that SQL is hard to read once it reaches a certain amount of complexity (and that can happen really fast). Production is very slow and the code becomes hard to maintain. On the other hand, one can argue that it's more performant than using a lightweight ORM like SQLAlchemy. Did any of you make similar experience? Would you let handle PostgreSQL everything, as we do, or would you move the logic to Flask?
I hope to read some advices.
Have a great weekend!

/r/flask
https://redd.it/8ff41v
Changing Matplotlib fonts: Neophyte who uses Juno Jupyter for scientific plotting.

I know this may be a little more specialized to Matplotlib, as I’m one of those lowly matl*b to Python ship jumpers, for the purposes of plotting pretty data and performing analyses on it. But I’m stuck somewhere that while trivial, will nevertheless drive me nuts as a strongly visual person: If anyone could provide guidance for changing the font on either a global or per-plot basis for all labels and legends in a plot you would have my eternal gratitude. Using rcParams as in the matplotlib documentation gives:

/home/nbuser/anaconda3_501/lib/python3.6/site-packages/matplotlib/font_manager.py:1320: UserWarning: findfont: Font family ['sans-serif'] not found. Falling back to DejaVu Sans
(prop.get_family(), self.defaultFamily[fontext]))

/r/JupyterNotebooks
https://redd.it/8fbqru