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?










0















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.



first two maximum values



maximun










share|improve this question



















  • 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















0















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.



first two maximum values



maximun










share|improve this question



















  • 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













0












0








0


1






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.



first two maximum values



maximun










share|improve this question
















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.



first two maximum values



maximun







qgis pyqgis qgis-3 qgis-processing






share|improve this question















share|improve this question













share|improve this question




share|improve this question








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












  • 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










1 Answer
1






active

oldest

votes


















3














This expression will give you the second-largest value:



array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))


It works by



  1. put all the "fieldname" values into an array (ie, a list)

  2. remove all instances of the maximum value from the array

  3. sort the array from smallest to largest

  4. 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.






share|improve this answer























  • 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











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
);



);













draft saved

draft discarded


















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









3














This expression will give you the second-largest value:



array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))


It works by



  1. put all the "fieldname" values into an array (ie, a list)

  2. remove all instances of the maximum value from the array

  3. sort the array from smallest to largest

  4. 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.






share|improve this answer























  • 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















3














This expression will give you the second-largest value:



array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))


It works by



  1. put all the "fieldname" values into an array (ie, a list)

  2. remove all instances of the maximum value from the array

  3. sort the array from smallest to largest

  4. 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.






share|improve this answer























  • 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













3












3








3







This expression will give you the second-largest value:



array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))


It works by



  1. put all the "fieldname" values into an array (ie, a list)

  2. remove all instances of the maximum value from the array

  3. sort the array from smallest to largest

  4. 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.






share|improve this answer













This expression will give you the second-largest value:



array_last(array_sort(array_remove_all( array_agg( "fieldname"), maximum("fieldname"))))


It works by



  1. put all the "fieldname" values into an array (ie, a list)

  2. remove all instances of the maximum value from the array

  3. sort the array from smallest to largest

  4. 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.







share|improve this answer












share|improve this answer



share|improve this answer










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

















  • 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

















draft saved

draft discarded
















































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.




draft saved


draft discarded














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





















































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







Popular posts from this blog

រឿង រ៉ូមេអូ និង ហ្ស៊ុយលីយេ សង្ខេបរឿង តួអង្គ បញ្ជីណែនាំ

QGIS export composer to PDF scale the map [closed] Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?Print Composer QGIS 2.6, how to export image?QGIS 2.8.1 print composer won't export all OpenCycleMap base layer tilesSave Print/Map QGIS composer view as PNG/PDF using Python (without changing anything in visible layout)?Export QGIS Print Composer PDF with searchable text labelsQGIS Print Composer does not change from landscape to portrait orientation?How can I avoid map size and scale changes in print composer?Fuzzy PDF export in QGIS running on macSierra OSExport the legend into its 100% size using Print ComposerScale-dependent rendering in QGIS PDF output

PDF-ში გადმოწერა სანავიგაციო მენიუproject page