I have a line like this:
filter(lambda x: x == 1, [1, 1, 2])
Pylint is showing a warning:
W: 3: Used builtin function 'filter'
Why is that? is a list comprehension the recommended method?
Of course I can rewrite this like this:
[x for x in [1, 1, 2] if x == 1]
And I get no warnings, but I was wondering if there's a PEP for this?
I ran into the same problem and could not figure out
why the built-in function `input' is bad. I you intend
to disable it:
Once you like the settings:
Verify that your settings are in the file, e.g.:
After that you can use this file locally
or even use it as your default rcfile. For this I kindly refer you to
List comprehension is recommended in the tutorial example, which states
and by most answerers on SO's Python List Comprehension Vs. Map where it is
filter
if you are defining alambda
each timefilter
if the function is pre-definedfilter
andmap
if youmap
,map
, orTL;DR: use list comprehension in most cases
Pylint often chatters on about stuff it shouldn't. You can disable the warning in a .pylintrc file.
This page http://pylint-messages.wikidot.com/messages:w0141 indicates the problem is that filter and map have been superseded by list comprehensions.
A line like this in your pylintrc file will quiet the warning:
I've got the same warning on my project. I'm changing the source code to be py2/3 compatible, and pylint helps a lot.
Running
pylint --py3k
shows only errors about compatibility.In python 2, if use
filter
, it returns alist
:But in python 3,
filter
and other similar methods (map
,range
,zip
, ..) return a iterator, that is incompatible types and perhaps cause bugs in your code.To make your code python 2/3 compatible, I use a cheat sheet from python future site
To avoid this warning, you can use 4 approaches, that works on python 2 and 3:
1 - Using a list comprehension like you said.
2 - Using a
list
function, grant that return always is a materialized list, result is same on both python versions3 - Using
lfilter
, that's a future package import. It always return a list, uses filter on py2, andlist(filter(..)
on py3. So, both pythons got the same behaviour and you got a cleaner syntax.4 - The best! Use
filter
always on a loop, this way pylint don't give warnings, and it have a nice performance boost on python 3.Always prefer functions that works on python 3, because python 2 will be retired soon.