10 most annoying airline seatmate behaviors


I recently saw an interesting infographic about the top 10 most annoying airline seatmate behaviors. I decided to try to create a more efficient SAS graph to visualize the same data, and share it with you in this blog.

Not everyone is as fortunate as my buddy David (pictured below), who has a pilot license, and does not have to worry about annoying behaviors of random seatmates.


The rest of us non-pilots have to fly on commercial airlines, and the people sitting around us have a variety of behaviors - some good, and some annoying. Expedia's infographic about annoying seatmates was 'cute,' but I had to do so much scrolling to view the 1000x4515 pixel image that by the time I viewed the last few items, I had forgotten what the first few items were!

Therefore I decided to create a no-nonsense SAS graph that allows me to see and compare all the data, in a graph that easily fits on one page without scrolling. I first input the data into a SAS dataset, and then used the following minimal code to produce the default graph. Here's the code and the output:

proc gchart data=my_data;
hbar category / type=sum sumvar=percent;


That's a decent graph, and allows me to easily see and compare the 10 items ... but it could be a lot better with a little more work. Using several built-in options, and specifying characteristics in axis statements, I was able to get a graph that was much better looking, and also easier to compare the 10 items:

pattern1 v=s c=cx00B2EE; /* blue color */
axis1 label=none value=(j=right) offset=(4,4);
axis2 label=none major=none minor=none style=0;
proc gchart data=my_data;
hbar category / type=sum sumvar=percent descending nostats
maxis=axis1 raxis=axis2
noframe space=0 width=3.7 coutline=white
autoref clipref cref=graydd;


That's a fine graph, but there is always room for improvement! I found myself looking from left-to-right quite a bit, to see the bar text and then the bar height. So I thought, why not print the text inside the bar, so I don't have to look all the way on the left side of the graph? There's no built-in option to do that, but I suppressed the default text labels by using value=none on the axis statement, and then used data-driven annotate to write the text on the bars. Depending on your preference, either of these two graphs might suit your needs.

data my_anno; set my_data;
length text $100;
xsys='2'; ysys='2'; hsys='3'; when='a';
midpoint=category; x=percent;
function='label'; position='<'; style='albany amt/bold';
axis1 label=none value=none offset=(4,4);
axis2 label=none major=none minor=none style=0;
proc gchart data=my_data anno=my_anno;
hbar category / type=sum sumvar=percent descending nostats
maxis=axis1 raxis=axis2
noframe space=0 width=3.7 coutline=white
autoref clipref cref=graydd;


Do you agree with Expedia's "Top 10" list?  What's the most annoying behavior you've personally seen on a plane?


About Author

Robert Allison

The Graph Guy!

Robert has worked at SAS for over 20 years, and is perhaps the foremost expert in creating custom graphs using SAS/GRAPH. His educational background is in Computer Science, and he holds a BS, MS, and PhD from NC State University. He is the author of several conference papers, has won a few graphic competitions, and has written a book (SAS/GRAPH: Beyond the Basics).


  1. The most annoying person I ever encountered, was the guy in a middle seat who thought he was "entitled" to an aisle seat because he "paid so much".
    The stewardess was really great, and did not take his BS.
    Yeah, there are a lot of other selfish people.

  2. The first two often go together! Usually the 'rear-seat kicker' is a child whose 'inattentive parents' are completely oblivious.

  3. Really nice graphs!

    The most annoying person I sat next to was from Korea to DFW, and he was chewing and spitting skoal tobacco into a cup the entire flight.

  4. Robert, nice graph, it uses the bar space well, might as well put text in place of monotone bar color.
    Was the origin of the data a output from a proc freq on category?
    Thanks for your continued support of SAS via texts and social media.

    • Robert Allison
      Robert Allison on

      Thanks for the feedback!

      I'm not sure what tool Expedia used to summarize their survey data (SAS, or other). I just read the pre-summarized values, and entered them into a SAS dataset.

    • Robert Allison

      It was a tough decision how to justify the test in the bars. People are more used to seeing text left-justified. But in this case I chose right-justified so it would be easier to see the length of the bar & the text without having to move the eyes left/right. It would probably work out ok either way :)

  5. Rick Wicklin

    For your readers who use ODS graphics, here is a roughly equivalent graph:

    proc sgplot data=my_data;
    hbar category / response=percent 
            categoryorder=RespDesc datalabel=category;
    yaxis display=none;
    xaxis grid display=(nolabel);

Leave A Reply

Back to Top