How to obtain the maximum two values of a field, without having to do it manually in the attribute table? The Next CEO of Stack OverflowVia PyQgis how to refresh a modified CSV layer without having to reopen the file?Finding Median, Max and Min values from Raster Layers in QGISHow to get attribute values from vector features visible in the qgis canvasUpdate/change/commit an attribute/a field value “on the fly” in QGIS 3What geodetic reference system is QGIS using when providing latitude and longitude values for points using the field calculator?QGIS Attribute table - How to merge the values of $area field of several elements by the same attribute (point ID)?Getting maximum values of attribute of multiple Shapefiles merged into new shapefile in QGIS?Unexpected behaviour using Filter in QGIS 3.2QGIS RASTER CALCULATOR - Getting the Minimum and Maximum Values of a Raster LayerHow to display an attribute value from a related layer in Atlas?
Math-accent symbol over parentheses enclosing accented symbol (amsmath)
How to avoid supervisors with prejudiced views?
Writing differences on a blackboard
How to count occurrences of text in a file?
Can MTA send mail via a relay without being told so?
The exact meaning of 'Mom made me a sandwich'
Flying from Cape Town to England and return to another province
I want to delete every two lines after 3rd lines in file contain very large number of lines :
How to invert MapIndexed on a ragged structure? How to construct a tree from rules?
Why doesn't UK go for the same deal Japan has with EU to resolve Brexit?
Why did CATV standarize in 75 ohms and everyone else in 50?
Why does standard notation not preserve intervals (visually)
RigExpert AA-35 - Interpreting The Information
Is French Guiana a (hard) EU border?
Why, when going from special to general relativity, do we just replace partial derivatives with covariant derivatives?
Where do students learn to solve polynomial equations these days?
Why is my new battery behaving weirdly?
Should I cite using beginthebibliography or beginfilecontents*
Is there a difference between "Fahrstuhl" and "Aufzug"
INSERT to a table from a database to other (same SQL Server) using Dynamic SQL
Is it okay to majorly distort historical facts while writing a fiction story?
Does Germany produce more waste than the US?
Why isn't acceleration always zero whenever velocity is zero, such as the moment a ball bounces off a wall?
What is the value of α and β in a triangle?
How to obtain the maximum two values of a field, without having to do it manually in the attribute table?
The Next CEO of Stack OverflowVia PyQgis how to refresh a modified CSV layer without having to reopen the file?Finding Median, Max and Min values from Raster Layers in QGISHow to get attribute values from vector features visible in the qgis canvasUpdate/change/commit an attribute/a field value “on the fly” in QGIS 3What geodetic reference system is QGIS using when providing latitude and longitude values for points using the field calculator?QGIS Attribute table - How to merge the values of $area field of several elements by the same attribute (point ID)?Getting maximum values of attribute of multiple Shapefiles merged into new shapefile in QGIS?Unexpected behaviour using Filter in QGIS 3.2QGIS RASTER CALCULATOR - Getting the Minimum and Maximum Values of a Raster LayerHow to display an attribute value from a related layer in Atlas?
I have a layer of points corresponding to the vertices extracted from a polygon, and from these I need to obtain the two maximum values and save them in a new layer of points.
Because I have more than 150 layers of points I would like to know if it is possible to do it without having to open the table of attributes of each of these and select the values that interest me.
I tried using the field calculator using the expression "maximum(expression[,group_by][,filter])" but that would not have the second maximum.
qgis pyqgis qgis-3 qgis-processing
add a comment |
I have a layer of points corresponding to the vertices extracted from a polygon, and from these I need to obtain the two maximum values and save them in a new layer of points.
Because I have more than 150 layers of points I would like to know if it is possible to do it without having to open the table of attributes of each of these and select the values that interest me.
I tried using the field calculator using the expression "maximum(expression[,group_by][,filter])" but that would not have the second maximum.
qgis pyqgis qgis-3 qgis-processing
2
Do u mean u're searching a way to achieve this programmatically for your 150 layers ? Are they opened ? Are they named using the same scheme ? Getting the two max. values is easy using a query on the table but is your question rather how to automate the whole process ?
– snaileater
yesterday
2
Of course it isn't possible to find attribute values without opening the attribute table. But this is trivially simple to script. What have you tried?
– Vince
yesterday
Yes, I understand that it is essential to access the attribute table. I already tried the field calculator with the expression "maximun" but I would need the second highest value. How could I implement a query for this value?
– John
yesterday
add a comment |
I have a layer of points corresponding to the vertices extracted from a polygon, and from these I need to obtain the two maximum values and save them in a new layer of points.
Because I have more than 150 layers of points I would like to know if it is possible to do it without having to open the table of attributes of each of these and select the values that interest me.
I tried using the field calculator using the expression "maximum(expression[,group_by][,filter])" but that would not have the second maximum.
qgis pyqgis qgis-3 qgis-processing
I have a layer of points corresponding to the vertices extracted from a polygon, and from these I need to obtain the two maximum values and save them in a new layer of points.
Because I have more than 150 layers of points I would like to know if it is possible to do it without having to open the table of attributes of each of these and select the values that interest me.
I tried using the field calculator using the expression "maximum(expression[,group_by][,filter])" but that would not have the second maximum.
qgis pyqgis qgis-3 qgis-processing
qgis pyqgis qgis-3 qgis-processing
edited yesterday
Vince
14.8k32849
14.8k32849
asked yesterday
JohnJohn
254
254
2
Do u mean u're searching a way to achieve this programmatically for your 150 layers ? Are they opened ? Are they named using the same scheme ? Getting the two max. values is easy using a query on the table but is your question rather how to automate the whole process ?
– snaileater
yesterday
2
Of course it isn't possible to find attribute values without opening the attribute table. But this is trivially simple to script. What have you tried?
– Vince
yesterday
Yes, I understand that it is essential to access the attribute table. I already tried the field calculator with the expression "maximun" but I would need the second highest value. How could I implement a query for this value?
– John
yesterday
add a comment |
2
Do u mean u're searching a way to achieve this programmatically for your 150 layers ? Are they opened ? Are they named using the same scheme ? Getting the two max. values is easy using a query on the table but is your question rather how to automate the whole process ?
– snaileater
yesterday
2
Of course it isn't possible to find attribute values without opening the attribute table. But this is trivially simple to script. What have you tried?
– Vince
yesterday
Yes, I understand that it is essential to access the attribute table. I already tried the field calculator with the expression "maximun" but I would need the second highest value. How could I implement a query for this value?
– John
yesterday
2
2
Do u mean u're searching a way to achieve this programmatically for your 150 layers ? Are they opened ? Are they named using the same scheme ? Getting the two max. values is easy using a query on the table but is your question rather how to automate the whole process ?
– snaileater
yesterday
Do u mean u're searching a way to achieve this programmatically for your 150 layers ? Are they opened ? Are they named using the same scheme ? Getting the two max. values is easy using a query on the table but is your question rather how to automate the whole process ?
– snaileater
yesterday
2
2
Of course it isn't possible to find attribute values without opening the attribute table. But this is trivially simple to script. What have you tried?
– Vince
yesterday
Of course it isn't possible to find attribute values without opening the attribute table. But this is trivially simple to script. What have you tried?
– Vince
yesterday
Yes, I understand that it is essential to access the attribute table. I already tried the field calculator with the expression "maximun" but I would need the second highest value. How could I implement a query for this value?
– John
yesterday
Yes, I understand that it is essential to access the attribute table. I already tried the field calculator with the expression "maximun" but I would need the second highest value. How could I implement a query for this value?
– John
yesterday
add a comment |
1 Answer
1
active
oldest
votes
This expression will give you the second-largest value:
array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))
It works by
- put all the "fieldname" values into an array (ie, a list)
- remove all instances of the maximum value from the array
- sort the array from smallest to largest
- extract the last value in the array
Note: This solution will work in QGIS 3.6 and later. The array_sort
function doesn't exist in earlier versions.
thanks, it works great
– John
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
add a comment |
Your Answer
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "79"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f317098%2fhow-to-obtain-the-maximum-two-values-of-a-field-without-having-to-do-it-manuall%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
This expression will give you the second-largest value:
array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))
It works by
- put all the "fieldname" values into an array (ie, a list)
- remove all instances of the maximum value from the array
- sort the array from smallest to largest
- extract the last value in the array
Note: This solution will work in QGIS 3.6 and later. The array_sort
function doesn't exist in earlier versions.
thanks, it works great
– John
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
add a comment |
This expression will give you the second-largest value:
array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))
It works by
- put all the "fieldname" values into an array (ie, a list)
- remove all instances of the maximum value from the array
- sort the array from smallest to largest
- extract the last value in the array
Note: This solution will work in QGIS 3.6 and later. The array_sort
function doesn't exist in earlier versions.
thanks, it works great
– John
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
add a comment |
This expression will give you the second-largest value:
array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))
It works by
- put all the "fieldname" values into an array (ie, a list)
- remove all instances of the maximum value from the array
- sort the array from smallest to largest
- extract the last value in the array
Note: This solution will work in QGIS 3.6 and later. The array_sort
function doesn't exist in earlier versions.
This expression will give you the second-largest value:
array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))
It works by
- put all the "fieldname" values into an array (ie, a list)
- remove all instances of the maximum value from the array
- sort the array from smallest to largest
- extract the last value in the array
Note: This solution will work in QGIS 3.6 and later. The array_sort
function doesn't exist in earlier versions.
answered yesterday
cskcsk
9,4751035
9,4751035
thanks, it works great
– John
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
add a comment |
thanks, it works great
– John
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
thanks, it works great
– John
yesterday
thanks, it works great
– John
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
Happy to help. You can mark this answer as accepted by clicking the checkmark next to the answer. That way others with the same question will know that this method works.
– csk
yesterday
add a comment |
Thanks for contributing an answer to Geographic Information Systems Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f317098%2fhow-to-obtain-the-maximum-two-values-of-a-field-without-having-to-do-it-manuall%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
2
Do u mean u're searching a way to achieve this programmatically for your 150 layers ? Are they opened ? Are they named using the same scheme ? Getting the two max. values is easy using a query on the table but is your question rather how to automate the whole process ?
– snaileater
yesterday
2
Of course it isn't possible to find attribute values without opening the attribute table. But this is trivially simple to script. What have you tried?
– Vince
yesterday
Yes, I understand that it is essential to access the attribute table. I already tried the field calculator with the expression "maximun" but I would need the second highest value. How could I implement a query for this value?
– John
yesterday