0 / 0 / 0
Регистрация: 24.02.2013
Сообщений: 67

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

15.02.2018, 00:20. Показов 1679. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru