Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 24.02.2013
Сообщений: 67

Реализовать три элементарных задачи

15.02.2018, 00:20. Показов 1676. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребятки, помогите человеку который совсем не знает Питона, на примере этого примитивного кода показать как в нём выполнить следующие три задачи.

1. Когда создаю новый файл эксель "питоном", как в примере, то старый затирается, это не есть хорошо, покажите как открывать уже существующий файл и в него добавлять эти таблички, не затирая содержимого старого файла.
2. Как вставлять сформированные «питоном» любые таблички начиная с нужной мне ячейки, например с «F8», а не как в этом примере они всегда попадают в ячейку «А1» конкретного листа эксельки, то же на этом примере.
3. И напоследок, есть набор цифр взятых с сайта «питоном», но все цифры формируются в табличке с точкой после значащего знака "." (пример 0.123), как было на сайте, а в эксельки все расчеты с цифрами можно производить только с запятой (пример 0,123), как "питоном" можно изменить все точки в цифрах на запятые, что бы загруженная в файл экселя табличка из этих цифр была сразу готова для полноценной работы с ней, а не приходилось в экселе менять в цифрах «точки» на запятые, можно на любом своем примитивном примере.

Буду Вам премного благодарен, изучать все возможности «питона» просто нет времени, нужно выполнить только эту задачу и всё. Спасибо за помощь.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# Создадим Excel файл
wb = Workbook()
# Выбрать активную книгу
ws = wb.active
# Присвоить имя листу
ws.title = "Таблица"
ws1 = wb.create_sheet("Пара1")
ws2 = wb.create_sheet("Пара2")
 
# Вставим заголовки
ws1.append(["ПАРА", "ПОКУПКА 1", "№"])
ws2.append(["ПАРА", "ПОКУПКА 2", "№"])
 
# Тут нужна любая табличка цифр, где точки в них преобразуются в запятые, любая в качестве примера.
 
 
# Сохраним файл
wb.save("pary.xlsx")
 
print('Завершение программы')
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.02.2018, 00:20
Ответы с готовыми решениями:

Задачи по c# от элементарных и далее
Привет! Посоветуйте, пожалуйста, книжку или какой-либо сайт где можно найти задачи по c# от элементарных и далее. Было бы очень удобно если...

Из какого числа равновозможных элементарных исходов состоит пространство элементарных исходов эксперимента?
Из какого числа равновозможных элементарных исходов состоит пространство элементарных исходов эксперимента: выбор одного пирожка из 9 с...

Реализовать метод Гаусса (метод элементарных преобразований) для вычисления ранга произвольной матрицы
Написать программу, реализующую метод Гаусса (метод элементарных преобразований) для вычисления ранга произвольной матрицы A-m*n, где n...

7
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
15.02.2018, 01:28
Что касается работы с Excel, то прочитать можно тут

замену в строке можно сделать так

Python
1
2
string = "0.123"
string.replace('.', ',')
0
0 / 0 / 0
Регистрация: 24.02.2013
Сообщений: 67
16.02.2018, 22:34  [ТС]
Изучал, изучал, так элементарных вещей и не осилил...
1. Да файл вроде стал открывается для записи, но запись идет все равно не туда куда надо или добавляет новых листов, дублируя их имена, а не добавляет данные на старые листы
2. Запись делать начиная от нужной мне ячейки таблицы данных в файле, не получилось пишет все равно в новые листы открытого для записи файла.
3. Перевод точки, в запятую в примере работает для одной циферки, а вот как эту запятую поменять во всей любой таблице данных из 100 строк, полученных с сайта?

Эх все таки рабочий примерчик, не помешал бы или как исправить это моё безобразие.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
from openpyxl import load_workbook
 
# Загружаем Excel файл
wb = load_workbook('./pary.xlsx')
# Выбрать активную книгу
ws = wb.active
# Присвоить имя листу
ws.title = "Таблица"
ws1 = wb.create_sheet("Пара1")
ws2 = wb.create_sheet("Пара2")
 
# Вставим заголовки
ws1.append(["ПАРА", "ПОКУПКА 1", "№"])
ws2.append(["ПАРА", "ПОКУПКА 2", "№"])
 
# Тут нужна любая табличка цифр, где точки в них преобразуются в запятые, любая в качестве примера.
string = "0.123"
string.replace('.', ',')
 
# Сохраним файл
wb.save("./pary.xlsx")
 
print('Завершение программы')
0
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
17.02.2018, 00:08
Цитата Сообщение от kiramiD Посмотреть сообщение
3. Перевод точки, в запятую в примере работает для одной циферки, а вот как эту запятую поменять во всей любой таблице данных из 100 строк, полученных с сайта?
Python
1
2
3
4
5
#приходит допустим массив данных
s = ['0.123 0.123', '0.124', '0.125']
 
#а так меняем точку на запятую во всем массиве
s = list(map(lambda x: x.replace('.', ','), s))
0
0 / 0 / 0
Регистрация: 24.02.2013
Сообщений: 67
17.02.2018, 00:49  [ТС]
Запутали ещё больше человека с нулевым знанием "питона"
Есть у меня вот программа которая на экран и в файл выдаёт 0.000, помогите в ней от этой точки избавиться, поменяв её на запятую и эту табличку в файл писать начиная с ячейки "В3" эксельки.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import json
import math
import requests
import os
from openpyxl import Workbook
 
res = requests.get('https://yobit.net/api/3/info') # получаем данные
res_obj = json.loads(res.text) # переводим полученный текст в объект с данными
 
pairs1 = [pair for pair in res_obj['pairs'] if 'doge_eth' in pair] # создадим массив
 
# Создадим Excel файл
wb = Workbook()
 
# Выбрать активную книгу
ws = wb.active
 
# Присвоить имя листу
ws.title = "Таблица"
ws1 = wb.create_sheet("Пары1")
 
# Вставим заголовки
ws1.append(["ПАРА", "ПОКУПКА 1"])
 
cnt1 = 1
# Проходим цикл по 1 паре, отбирая каждый раз по 50 пар
for i in range(0, int(math.ceil(len(pairs1)/50))):
    pairs1_str = '-'.join(pairs1[i*50:(i+1)*50]) # формируем строку для передачи тикеру
 
    ticker_res = requests.get('https://yobit.net/api/3/ticker/'+pairs1_str) # получаем данные
    ticker_res_obj = json.loads(ticker_res.text) # переводим полученный текст в объект с данными
    
    for pair in ticker_res_obj:
        print(
            pair,
            '%0.3f' % ticker_res_obj[pair]['sell']
        )
        ws1.append([
            pair,
            '%0.3f' % ticker_res_obj[pair]['sell']
        ])
        cnt1 += 1
 
# Сохраним файл рядом со скриптом
wb.save("pary.xlsx")
 
print('Завершение работы программы')
0
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
17.02.2018, 01:45
Лучший ответ Сообщение было отмечено kiramiD как решение

Решение

Вот например, но это тупой вариант, надо как следует справку почитать

Python
1
2
3
4
5
6
7
8
9
for i,pair in enumerate(ticker_res_obj):
        string = ('%0.3f' % ticker_res_obj[pair]['sell'])
        print(pair, string)
        i += 3
        ws1['B' + str(i)] = pair
        ws1['C' + str(i)].number_format = '0.000'
        ws1['C' + str(i)] = float(string)
 
        cnt1 += 1
1
0 / 0 / 0
Регистрация: 24.02.2013
Сообщений: 67
17.02.2018, 02:53  [ТС]
Спасибо, то что нужно, не без мелких шероховатостей, т.к. эта конструкция затирает строки если их больше 50 бывает, т.к каждый цикл начинает со строки "B3", первый Ваш вариант даже более предпочтителен оказался, но с этим я справлюсь сам. Благодарю за помощь.
Правда вопрос номер один остался в силе, как открывать уже существующий файл делать в него эту запись и сохранять не плодя лишних сущностей в файле (лишних листов) и не перезатирая в нем таблиц и формул расчета которые там уже могут существовать?
0
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
17.02.2018, 04:38
Цитата Сообщение от kiramiD Посмотреть сообщение
как открывать уже существующий файл делать в него эту запись и сохранять не плодя лишних сущностей в файле
Можно вот так

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
# Создадим Excel файл
try:
    # Открываем существующий файл
    wb = load_workbook("pary.xlsx")
    # Переходим к нужному листу
    ws1 = wb["Пары1"]
except:
    # Создаем новый файл
    wb = Workbook()
    # Берем первый лист
    ws = wb.active
    # Сразу переименовываем, чтобы не было лишних листов
    ws.title = "Пары1"
Цитата Сообщение от kiramiD Посмотреть сообщение
е перезатирая в нем таблиц и формул расчета которые там уже могут существовать
Можно определить число записей в столбце и начать запись после последней
Python
1
2
first_column = ws1['B']
ws1["B" + str(len(first_column)+1)] = 'Данные'
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.02.2018, 04:38
Помогаю со студенческими работами здесь

Реализовать иерархию классов, где три класса описывающих поведение транспортные средства. Все три класса наследуются
Реализовать иерархию классов, где три класса описывающих поведение транспортные средства. Все три класса наследуются в с++

C. Три задачи
Добрый день, не подскажите как можно решить данную задачу? Задача: Петя участвует в олимпиаде по программированию. Олимпиада...

Три задачи.
1)Напишите программу, которая вводит несколько строк текста и символ поиска и использует функцию strchr, чтобы определить суммарное число...

три задачи
1) Тема : "Работа с массивами". n точек на плоскости задано последовательностями паp своих кооpдинат x1,...,xn ; y1,...yn...

Три задачи.
Дано 3 задания. вот ссылка. http://dikey.ex6.ru/P1010018.JPG Кто нибудь сделайте!! помогите бездарному прогеру!!! киньте архив с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Номеклатура. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru