Вместо макета Flexbox используйте вид рециркулятора с диспетчером макетов сетки. Например:
recyclerView.setLayoutManager(new GridLayoutManager(this,3));
import os
rows, columns = os.popen('stty size', 'r').read().split()
использует команду 'stty size', которая, согласно , ветка в списке рассылки python является достаточно универсальной для Linux. Он открывает команду 'stty size' как файл, "читает" из него и использует простое разделение строк для разделения координат.
В отличие от значения os.environ ["COLUMNS"] (к которому я не могу получить доступ несмотря на использование bash в качестве стандартной оболочки) данные также будут актуальными, тогда как я считаю, что значение os.environ ["COLUMNS"] будет действительным только на время запуска интерпретатора python (предположим, что с тех пор пользователь изменил размер окна).
используйте
import console
(width, height) = console.getTerminalSize()
print "Your terminal's width is: %d" % width
РЕДАКТИРОВАНИЕ : о, я сожалею. Это не lib стандарта Python один, вот источник console.py (я не знаю, откуда это).
модуль, кажется, работает как этот: Это проверяет, доступно ли termcap
, когда да. Это использует это; если не это проверяет, поддерживает ли терминал специальное предложение ioctl
вызов, и это не работает также, это проверяет на переменные среды некоторый экспорт оболочек для этого. Это будет, вероятно, работать над UNIX только.
def getTerminalSize():
import os
env = os.environ
def ioctl_GWINSZ(fd):
try:
import fcntl, termios, struct, os
cr = struct.unpack('hh', fcntl.ioctl(fd, termios.TIOCGWINSZ,
'1234'))
except:
return
return cr
cr = ioctl_GWINSZ(0) or ioctl_GWINSZ(1) or ioctl_GWINSZ(2)
if not cr:
try:
fd = os.open(os.ctermid(), os.O_RDONLY)
cr = ioctl_GWINSZ(fd)
os.close(fd)
except:
pass
if not cr:
cr = (env.get('LINES', 25), env.get('COLUMNS', 80))
### Use get(key[, default]) instead of a try/catch
#try:
# cr = (env['LINES'], env['COLUMNS'])
#except:
# cr = (25, 80)
return int(cr[1]), int(cr[0])
Приведенный выше код не дал корректного результата на моем linux, потому что winsize-struct имеет 4 беззнаковых шорта, а не 2 знаковых:
def terminal_size():
import fcntl, termios, struct
h, w, hp, wp = struct.unpack('HHHH',
fcntl.ioctl(0, termios.TIOCGWINSZ,
struct.pack('HHHH', 0, 0, 0, 0)))
return w, h
hp и hp должны содержать ширину и высоту пикселя, но не содержат.
Похоже, с этим кодом возникли некоторые проблемы, Йоханнес:
getTerminalSize
необходимо импортировать ОС
env
? выглядит как os.environ
. Кроме того, зачем переключать строки
и столбцы
перед возвратом? Если TIOCGWINSZ
и stty
оба говорят строки
, то cols
, я предлагаю оставить это как есть. Это сбило меня с толку в течение добрых 10 минут, прежде чем я заметил несоответствие.
Шридхар, я не получал этой ошибки, когда передавал вывод по конвейеру. Я почти уверен, что при попытке его поймали правильно - за исключением.
паскаль, «ЧЧЧ»
не работает на моей машине, но «чч»
работает. Мне не удалось найти документацию по этой функции. Похоже, это зависит от платформы.
chochem, inc.
Вот моя версия:
def getTerminalSize():
"""
returns (lines:int, cols:int)
"""
import os, struct
def ioctl_GWINSZ(fd):
import fcntl, termios
return struct.unpack("hh", fcntl.ioctl(fd, termios.TIOCGWINSZ, "1234"))
# try stdin, stdout, stderr
for fd in (0, 1, 2):
try:
return ioctl_GWINSZ(fd)
except:
pass
# try os.ctermid()
try:
fd = os.open(os.ctermid(), os.O_RDONLY)
try:
return ioctl_GWINSZ(fd)
finally:
os.close(fd)
except:
pass
# try `stty size`
try:
return tuple(int(x) for x in os.popen("stty size", "r").read().split())
except:
pass
# try environment variables
try:
return tuple(int(os.getenv(var)) for var in ("LINES", "COLUMNS"))
except:
pass
# i give up. return default.
return (25, 80)